Book review: The Definitive Guide to SQLite by <i>Michael Owens</i>

Book review: The Definitive Guide to SQLite by Michael Owens


With so many database engine choices, it’s not easy to choose one. For those that choose SQLite, Michael Owens makes it easy to configure and operate. As the original creator of PySQLite, he knows a thing or two about this free and powerful database engine.

The book’s cover The book’s cover

The title of The Definitive Guide to SQLite may lead you to believe it’s just a reference to D. Richard Hipp’s insanely popular database. But Michael Owens does a great job of showing you it’s more than just another bit of free software. His first chapter is a good introduction into the world of SQLite. As he explains, SQLite is versatile enough for developers and administrators, as well as those who are fairly new to databases and SQL. He jumps right in, discussing some of the technical points of its architecture. Since databases vary in abilities, Owens isn’t afraid to tell you where SQLite isn’t the best choice. For instance, he explains that you cannot enforce foreign key constraints.

Michael Owens does a great job of showing you SQLite is more than just another bit of free software.

The contents

Since SQLite is in fact free software, Owens starts you off by telling you how to get the source code and binaries for the various packages available. Since SQLite is not just for POSIX systems, there are instructions for Windows (both command-line program and the DLL are available). Once you have everything installed, you’re walked through a quick tutorial of how to use SQLite in your shell. You’re shown how to create and open databases and tables, how to get information on your databases, and more. In case you’re not a huge fan of the command line, you’re pointed to a few graphical tools.

As with anything in life, you’re going to have to learn some of the boring parts of databases. Owens spends a chapter on the relational model. He explains all the necessary evils of how and why databases work, including constraints, keys, and normalization. It’s not his fault; every administrator has to learn all that. But he makes it easier to follow along.

Once you’re done with that fun, you’re introduced to SQL itself. The SQL tutorial is worth the price of the book. You can learn SQL anywhere, but in his words, you need to learn it well. Geeks like me will enjoy this section. You delve deep into databases, learning as much as he could fit without writing an entire book on SQL alone. And if you’re a Seinfeld fan, you’re going to love this book. Most of the data in his examples comes from that television show. (The necessary data is available from the book’s companion site.)

A database is no good without anything to use it for. You can learn SQL, but you wouldn’t be buying this unless you had a specific purpose. The language of choice for this text is C, and Owens walks you through the core C API and its extension. There are two chapters for the C API, and then you read about how to use SQLite with Perl, Python, Ruby, Java, Tcl (via the extension created by SQLite’s creator), and PHP. If you’re using something not listed, Owens points you to a useful wiki that will guide you to an interface.

Who’s this book for?

Anyone interested in learning about SQLite should definitely buy this. It’s been updated to cover the newest version 3 changes. Although the book is geared for beginner to intermediate users, even longtime experts will gain some useful information. Some of the very technical data is interesting for die hard database geeks. If all you’re looking for is an SQL reference, this is still a great book. It’s not just a SQLite-specific guide; it’s good for learning SQL in general.

Who’s this book not for?

Anyone who’s not willing to invest the time to read about SQL won’t like this book. This isn’t something you learn in a few quick steps. Keeping that in mind, if you’ve installed SQLite, more than likely you have a goal in mind for a database.

Relevance to free software

The Definitive Guide to SQLite is all about free software. From SQLite itself, to C, Perl, Python, and so on, Owens shows you a strong database without shelling out hundreds for proprietary solutions.

Pros

I highly recommend this book for anyone interested in databases. If you’re looking for a free software database, buy this book, install SQLite, and spend the time to learn it. You’ll be on your way to working with some of the best free software and one of the best books on databases.

Cons

While most of the developers will be using C, I felt the book was nearly completely geared for that language. Knowing that the author was the original creator of PySQLite, I thought he’d have a lot more about it. Furthermore, I wish he had included a few more examples for the language extensions. I wish he had created an appendix for SQLite, as he did with SQL and the C API. That’s not a con, just an idle wish.

Title The Definitive Guide to SQLite
Author Michael Owens
Publisher Apress, Inc.
ISBN 1590596730
Year 2006
Pages 440
CD included No
FS Oriented 10
Over all score 9

In short

Category: 
License: 

Author information

Raymond Burke's picture

Biography

As a young geek, comp sci teacher, computer repair specialist, and consultant, I've learned quite a few things about computers and their users, both technical and non-technical.

Most forwarded

Interview with Dave Mohyla, of DTIDATA

Dave Mohyla is the president and founder of dtidata.com, a hard drive recovery facility based in Tampa, Florida.

TM: Where are you based? What does your company do?
DTI Data recovery is based in South Pasadena, Florida which is a suburb of Tampa. We have been here for over 10 years. We operate a bio-metrically secured class 100 clean room where we perform hard drive recovery on all types of hard disks, from laptop hard drives to multi drive RAID systems.

Anybody up to writing good directory software?

Since the very beginning, directories (of any kind) have had a very central role in the internet. (I have recently grown fond of Free Web Directory. Even Slashdot can be considered a directory: a collection of great news and invaluable user-generated comments. As far as software is concerned, doing a quick search on Google about software directories will return the free (as in freedom) software directories like Savannah, SourceForge, Freshmeat and so on, followed by shareware and freeware sites such as FileBuzz, PCWin Download Center and All Freeware (great if you're looking for shareware and freeware, but definitely less comprehensive than their free-as-in-freedom counterparts).

Interview with Mark Shuttleworth

Mark Shuttleworth is the founder of Thawte, the first Certification Authority to sell public SSL certificates. After selling Thawte to Verisign, Mark moved on to training as an astronaut in Russia and visiting space. Once he got back he founded Ubuntu, the leading GNU/Linux distribution. He agreed on releasing a quick interview to Free Software Magazine.

Is better education the key to finding better software?

I read David Jonathon's article Anybody Up To Writing Good Directory Software? the other day, which got me thinking about software directories in general. As David mentioned, many of the software directories one finds when doing a quick google search are free as in beer, not as in freedom. But what interests me is the software directories that already exist, providing a combination of both free as in beer software, and open source software. Sites such as Freeware Downloads and Shareware Download don't advertise themselves as providing free as in liberty software, but each of them have a good selection of open source software available... if you know where to look.

Most emailed

Free Open Document label templates

If you’ve ever spent hours at work doing mailings, cursed your printer for printing outside the lines on your labels, or moaned “There has got to be a better way to do this,” here’s the solution you’ve been looking for. Working smarter, not harder! Worldlabel.com, a manufacture of labels offers Open Office / Libre Office labels templates for downloading in ODF format which will save you time, effort, and (if you want) make really cool-looking labels

Creating a user-centric site in Drupal

A little while ago, while talking in the #drupal mailing list, I showed my latest creation to one of the core developers there. His reaction was "Wow, I am always surprised what people use Drupal for". His surprise is somehow justified: I did create a site for a bunch of entertainers in Perth, a company set to use Drupal to take over the world with Entertainers.Biz.

Update: since writing this article, I have updated the system so that the whole booking process happens online. I will update the article accordingly!

So, why, why do people and companies develop free software?

More and more people are discovering free software. Many people only do so after weeks, or even months, of using it. I wonder, for example, how many Firefox users actually know how free Firefox really is—many of them realise that you can get it for free, but find it hard to believe that anybody can modify it and even redistribute it legally.

When the discovery is made, the first instinct is to ask: why do they do it? Programming is hard work. Even though most (if not all) programmers are driven by their higher-than-normal IQs and their amazing passion for solving problems, it’s still hard to understand why so many of them would donate so much of their time to creating something that they can’t really show off to anybody but their colleagues or geek friends.

Sure, anybody can buy laptops, and just program. No need to get a full-on lab or spend thousands of dollars in equipment. But... is that the full story?

Fun articles

Santa Claus - the most successful open source project

It dawned on me the other day, as I was shopping for the dozens of gifts it seems I have to buy every December, that Santa Claus is the most successful open source project in history. (Bridget @ Illiterarty would agree with that). Santa Claus is essentially a marketing development that is embodied by everyone who stuffs a sock, gives a gift, hosts a dinner or wishes Merry Christmas over the holiday season.

Most emailed

Editorial

When I first started thinking about Free Software Magazine, I was feeling enthusiastic about the dream. I had Dave, Gianluca, and Alan willing to help me, I had established members of the free software community willing to help me out, I had writers volunteering their time and energy for free, and I had a generous offer from OpenHosting for servers, all before I'd proved myself. There was a sense of excitement in the air, and I thought maybe, just maybe, I could make this work.

Free Software Magazine uses Apollo project management software and CRM for its everyday activities!