SQLite is a self-contained, server-less, config-free transactional SQL database engine. Python gained the sqlite3 module all the way back in version 2.5 which means that you can create SQLite database with any current Python without downloading any additional dependencies. Mozilla uses SQLite databases for its popular Firefox browser to store bookmarks and other various pieces of information. In this article you will learn the following:
- How to create a SQLite database
- How to insert data into a table
- How to edit the data
- How to delete the data
- Basic SQL queries
This article will be similar in function to the recent SQLAlchemy tutorial that appeared on this site earlier this month. If you want to inspect your database visually, you can use the SQLite Manager plugin for Firefox or if you like the command line, you can use SQLite’s command line shell
How to Create a Database and INSERT Some Data
Creating a database in SQLite is really easy, but the process requires that you know a little SQL to do it. Here’s some code that will create a database to hold music albums:
import sqlite3 conn = sqlite3.connect("mydatabase.db") # or use :memory: to put it in RAM cursor = conn.cursor() # create a table cursor.execute("""CREATE TABLE albums (title text, artist text, release_date text, publisher text, media_type text) """)
First we have to import the sqlite3 library and create a connection to the database. You can pass it a file path, file name or just use use the special string “:memory:” to create the database in memory. In our case, we created it on disk in a file called mydatabase.db. Next we create a cursor object, which allows you to interact with the database and add records, among other things. Here we use SQL syntax to create a table named albums with 5 text fields: title, artist, release_date, publisher and media_type. SQLite only supports five data types: null, integer, real, text and blob. Let’s build on this code and insert some data into our new table!
# insert some data cursor.execute("INSERT INTO albums VALUES ('Glow', 'Andy Hunter', '7/24/2012', 'Xplore Records', 'MP3')") # save data to database conn.commit() # insert multiple records using the more secure "?" method albums = [('Exodus', 'Andy Hunter', '7/9/2002', 'Sparrow Records', 'CD'), ('Until We Have Faces', 'Red', '2/1/2011', 'Essential Records', 'CD'), ('The End is Where We Begin', 'Thousand Foot Krutch', '4/17/2012', 'TFKmusic', 'CD'), ('The Good Life', 'Trip Lee', '4/10/2012', 'Reach Records', 'CD')] cursor.executemany("INSERT INTO albums VALUES (?,?,?,?,?)", albums) conn.commit()
Here we use the INSERT INTO SQL command to insert a record into our database. Note that each item had to have single quotes around it. This can get complicated when you need to insert strings that include single quotes in them. Anyway, to save the record to the database, we have to commit it. The next piece of code shows how add multiple records at once be using the cursor’s executemany method. Note that we’re using question marks (?) instead of string substitution (%s) to insert the values. Using string substitution is NOT safe and should not be used as it can allow SQL injection attacks to occur. The question mark method is much better and using SQLAlchemy is even better because it does all the escaping for you so you won’t have to mess with the annoyances of converting embedded single quotes into something that SQLite will accept.
Updating and Deleting Records
Being able to update your database records is key to keeping your data accurate. If you can’t update, then your data will become out of date and pretty useless very quickly. Sometimes you will need to delete rows from your data too. We’ll be covering both of those topics in this section. First, let’s do an update!
import sqlite3 conn = sqlite3.connect("mydatabase.db") cursor = conn.cursor() sql = """ UPDATE albums SET artist = 'John Doe' WHERE artist = 'Andy Hunter' """ cursor.execute(sql) conn.commit()
Here we use SQL’s UPDATE command to update out albums table. You can use SET to change a field, so in this case we change the artist field to be “John Doe” in any record WHERE the artist field is set to “Andy Hunter”. Wasn’t that easy? Note that if you don’t commit the changes, then your changes won’t be written out to the database. The DELETE command is almost as easy. Let’s check that out!
import sqlite3 conn = sqlite3.connect("mydatabase.db") cursor = conn.cursor() sql = """ DELETE FROM albums WHERE artist = 'John Doe' """ cursor.execute(sql) conn.commit()
Deleting is even easier than updating. The SQL is only 2 lines! In this case, all we had to do was tell SQLite which table to delete from (albums) and which records to delete using the WHERE clause. Thus is looked for any records that had “John Doe” in its artist field and deleted it.
Basic SQLite Queries
Queries in SQLite are pretty much the same as what you’d use for other databases, such as MySQL or Postgres. You just use normal SQL syntax to run the queries and then have the cursor object execute the SQL. Here are a few examples:
import sqlite3 conn = sqlite3.connect("mydatabase.db") #conn.row_factory = sqlite3.Row cursor = conn.cursor() sql = "SELECT * FROM albums WHERE artist=?" cursor.execute(sql, [("Red")]) print cursor.fetchall() # or use fetchone() print "\nHere's a listing of all the records in the table:\n" for row in cursor.execute("SELECT rowid, * FROM albums ORDER BY artist"): print row print "\nResults from a LIKE query:\n" sql = """ SELECT * FROM albums WHERE title LIKE 'The%'""" cursor.execute(sql) print cursor.fetchall()
The first query we execute is a SELECT * which means that we want to select all the records that match the artist name we pass in, which in this case is “Red”. Next we execute the SQL and use fetchall() to return all the results. You can also use fetchone() to grab the first result. You’ll also notice that there’s a commented out section related to a mysterious row_factory. If you un-comment that line, the results will be returned as Row objects that are kind of like Python dictionaries and give you access to the row’s fields just like a dictionary. However, you cannot do item assignment with a Row object.
The second query is much like the first, but it returns every record in the database and orders the results by the artist name in ascending order. This also demonstrates how we can loop over the results. The last query shows how to use SQL’s LIKE command to search for partial phrases. In this case, we do a search of the entire table for titles that start with “The”. The percent sign (%) is a wildcard operator.
Wrapping Up
Now you know how to use Python to create a SQLite database. You can also create, update and delete records as well as run queries against your database. Go out and start your own neat databases and / or share your experiences in the comments!
Further Reading
- Python official documentation for the sqlite3 library
- Zetcode’s SQLite tutorial
- A Simple SqlAlchemy 0.7 / 0.8 Tutorial
Source Code
Is there a way to store dates and datetime in SQLite and how to show results sorted by date.
Just wanted to say that I follow your posts religiously and it’s thanks to you I’ve stuck to learning python. This particular tutorial is of great use as I just took over managing a local non-profit site and this will help me manage membership. Thanks again 🙂
I didn’t think so, but I looked it up and there appears to be a timestamp datatype that wasn’t listed on the SQLite website. If you use that, then you can use datetime. See this StackOverflow thread: http://stackoverflow.com/questions/1829872/read-datetime-back-from-sqlite-as-a-datetime-in-python
I’m glad you like them so much. Personally I prefer using SQLAlchemy over using SQLite directly, but you should use whatever makes sense to you.
 Thanks
Thanks for this helpful post.
One thing I found confusing as first however was this line (because it contains what looks like a tuple, but is just redundant parens):
cursor.execute(sql, [(“Red”)])
It would be clearer as:
cursor.execute(sql, (“Red”,))
Cheers
after going through your website i found it is very important to me, so to do with this do i need sqlite software?
How do you set multiple columns, would you just use commas on the SET statement ?
I believe so. See http://www.basic4ppc.com/forum/questions-windows-mobile/2104-updating-multiple-columns-sqlite.html
Pingback: How to work with sqlite3 and Python | BlogoSfera
Pingback: Mike Driscoll: Python 101: How to Grab Data from RottenTomatoes | The Black Velvet Room
Pingback: Python 101: How to Grab Data from RottenTomatoes | Hello Linux
Pingback: Mike Driscoll: Top Ten Articles of 2013 | The Black Velvet Room
Pingback: Top Ten Articles of 2013 | Hello Linux
Could we see an example of how to capture sqlite3 responses in python after regular insert/update executes? All the sample code I’ve seen appears to ignore the db response, assuming there were no issues.
Thanks
Its so much helpful !
Thanks a lot 🙂
Thanks for this helpful post.
Pingback: Manipuler les bases de données SQL dans Pepper – PwavRobot – Formation àPepper
why have you used cursor however connection can be made as conn=sqlite3.connect(“regform.db”)?
can you please explain how to establish a connection between a python file and a database?
Pingback: Python 101: How to Grab Data from RottenTomatoes - The Mouse Vs. The Python