How to Use SQLite With Python?

8 minutes read

SQLite is a lightweight, stand-alone database engine that doesn't require any server to operate. It is widely used due to its simplicity and compatibility. In Python, you can easily incorporate SQLite into your applications using the built-in sqlite3 module.


First, you need to import the sqlite3 module by including the following line at the beginning of your script:

1
import sqlite3


To start using SQLite, you typically need to follow these steps:

  1. Connect to the database:
1
conn = sqlite3.connect('database.db')


Here, 'database.db' represents the name or path of the database file you want to connect to. If the file doesn't exist, SQLite will create it for you.

  1. Create a cursor object:
1
cursor = conn.cursor()


The cursor object allows you to execute SQL statements and fetch data from the database.

  1. Execute SQL statements: SQLite supports standard SQL commands like SELECT, INSERT, UPDATE, and DELETE. You can execute them using the execute() method of the cursor object:
1
2
cursor.execute("CREATE TABLE IF NOT EXISTS employees (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)")
cursor.execute("INSERT INTO employees (name, age) VALUES ('John Doe', 25)")


  1. Commit the changes (if necessary): If you make any modifications to the database (e.g., creating tables, inserting data), you need to commit those changes:
1
conn.commit()


If you only perform read operations, committing is not necessary.

  1. Retrieve data from the database: To fetch data from a table, use the execute() method followed by the fetchone() or fetchall() methods of the cursor object:
1
2
3
4
cursor.execute("SELECT * FROM employees")
rows = cursor.fetchall()
for row in rows:
    print(row)


  1. Close the database connection: To free up resources properly, close the connection when you are finished working with the database:
1
conn.close()


These steps provide a basic overview of using SQLite with Python. You can explore more advanced features like creating indices, executing parameterized queries, or working with transactions as your needs evolve.

Best SQLite Books to Read in 2025

1
The Definitive Guide to SQLite (Expert's Voice in Open Source)

Rating is 5 out of 5

The Definitive Guide to SQLite (Expert's Voice in Open Source)

2
The Definitive Guide to SQLite

Rating is 4.9 out of 5

The Definitive Guide to SQLite

3
Using SQLite: Small. Fast. Reliable. Choose Any Three.

Rating is 4.8 out of 5

Using SQLite: Small. Fast. Reliable. Choose Any Three.

4
Creating SQL Queries Using SQLite Made Easy (SQL Series)

Rating is 4.7 out of 5

Creating SQL Queries Using SQLite Made Easy (SQL Series)

5
SQLite For Beginners: Learn Fundamentals of Queries and Implement PyQt-Based Projects Easily

Rating is 4.6 out of 5

SQLite For Beginners: Learn Fundamentals of Queries and Implement PyQt-Based Projects Easily

6
SQL Pocket Guide: A Guide to SQL Usage

Rating is 4.5 out of 5

SQL Pocket Guide: A Guide to SQL Usage


How can I group rows and apply aggregate functions in SQLite using Python?

To group rows and apply aggregate functions in SQLite using Python, you can utilize the "GROUP BY" clause along with various aggregate functions such as SUM, AVG, MIN, MAX, COUNT, etc. Here's an example:

  1. First, establish a connection to the SQLite database using the sqlite3 library:
1
2
3
4
import sqlite3

conn = sqlite3.connect('your_database.db')
cursor = conn.cursor()


  1. Execute the SQL query using the execute() method and retrieve the results using the fetchall() method:
1
2
cursor.execute("SELECT column1, column2, COUNT(column3) as count FROM your_table GROUP BY column1, column2")
rows = cursor.fetchall()


In the above query, replace your_database.db with the name of your SQLite database file, your_table with the name of the table you want to query, and column1, column2, and column3 with the actual column names.

  1. Iterate over the retrieved rows and process the data as per your needs:
1
2
3
4
5
6
7
for row in rows:
    column1_value = row[0]
    column2_value = row[1]
    count = row[2]
    
    # Process the data (e.g., print, store in variables, etc.)
    print(f"Column1: {column1_value}, Column2: {column2_value}, Count: {count}")


You can replace the print() function with your desired logic to handle the grouped and aggregated data.

  1. Close the database connection when you're done:
1
conn.close()


Remember to call the close() method to free up system resources.


How do I create and execute prepared statements in SQLite with Python?

In order to create and execute prepared statements in SQLite with Python, you can use the sqlite3 module that comes with the Python standard library. Here's an example of how to do it:

  1. Import the sqlite3 module:
1
import sqlite3


  1. Connect to the SQLite database:
1
conn = sqlite3.connect('your_database.db')


  1. Create a cursor object to execute SQL statements:
1
cursor = conn.cursor()


  1. Prepare the SQL statement using placeholders (?) for parameters:
1
stmt = "SELECT * FROM your_table WHERE column1 = ? AND column2 = ?"


  1. Execute the prepared statement with parameters using the execute() method:
1
cursor.execute(stmt, (value1, value2))


Note: (value1, value2) should be a tuple containing values for the placeholders in the same order as they appear in the statement.

  1. Fetch the results of the executed statement:
1
results = cursor.fetchall()


  1. Close the cursor and the database connection:
1
2
cursor.close()
conn.close()


Here's the complete code snippet for better understanding:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
import sqlite3

conn = sqlite3.connect('your_database.db')
cursor = conn.cursor()

stmt = "SELECT * FROM your_table WHERE column1 = ? AND column2 = ?"
cursor.execute(stmt, (value1, value2))

results = cursor.fetchall()

cursor.close()
conn.close()


Remember to replace your_database.db, your_table, column1, column2, value1, and value2 with your actual database name, table name, column names, and respective values.


How do I create a new table in SQLite with Python?

To create a new table in SQLite using Python, you need to follow these steps:

  1. Start by importing the necessary SQLite module:
1
import sqlite3


  1. Establish a connection to the SQLite database. This will create a new database file if it doesn't exist:
1
conn = sqlite3.connect('database.db')


  1. Create a cursor object to execute SQLite commands:
1
cursor = conn.cursor()


  1. Write a CREATE TABLE SQL command to define the new table structure. For example, to create a table called "users" with columns "id", "name", and "email":
1
2
3
4
5
create_table_query = '''CREATE TABLE users (
                        id INTEGER PRIMARY KEY,
                        name TEXT NOT NULL,
                        email TEXT NOT NULL
                      )'''


  1. Execute the CREATE TABLE command using the cursor:
1
cursor.execute(create_table_query)


  1. Commit the changes to the database and close the connection:
1
2
conn.commit()
conn.close()


That's it! You have successfully created a new table in SQLite using Python.

Facebook Twitter LinkedIn Telegram Whatsapp Pocket

Related Posts:

Backing up a SQLite database is essential to ensure data integrity and prevent loss in case of accidents or emergencies. Here's an overview of how to backup a SQLite database:Connect to the SQLite database: First, establish a connection to the database usi...
To open an encrypted SQLite database file, follow these steps:Download and install an SQLite database management tool like DB Browser for SQLite or SQLiteStudio.Launch the SQLite database management tool.Locate the encrypted SQLite database file on your comput...
SQLite is a popular database management system that is lightweight and easy to use. It is often used in small-scale applications and mobile development due to its simplicity and versatility. In order to use SQLite with Java, you need to follow a set of steps:I...