w3resource

Step-by-Step Guide to Using SQLite with SQLAlchemy


Using SQLite with SQLAlchemy: A Complete Guide

SQLAlchemy is a popular Python ORM (Object-Relational Mapper) that simplifies database interactions by allowing developers to interact with databases like SQLite using Python objects and methods instead of raw SQL queries. This guide covers the integration of SQLite with SQLAlchemy, focusing on creating tables, performing CRUD operations, and managing data efficiently.


Why Use SQLAlchemy with SQLite?

    1. Ease of Use: Write Pythonic code to interact with the SQLite database.

    2. Abstraction: Provides a high-level interface for managing database schemas and queries.

    3. Flexibility: Supports raw SQL for complex queries.

    4. Cross-Compatibility: SQLAlchemy works with multiple databases, including SQLite, MySQL, PostgreSQL, and more.


Installing SQLAlchemy

Before using SQLAlchemy, install it using pip:

pip install sqlalchemy

Connecting SQLAlchemy to SQLite

Code:

from sqlalchemy import create_engine

# Create an SQLite database (or connect if it exists)
engine = create_engine("sqlite:///example.db")  # Use the SQLite driver

# Verify connection by printing the engine object
print("Connected to database:", engine)

Explanation

  • create_engine: Establishes a connection to the SQLite database.
  • sqlite:///example.db: Creates a file-based SQLite database named example.db in the current directory.

Defining a Table with SQLAlchemy ORM

Code:

from sqlalchemy import Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base

# Define the base class for table models
Base = declarative_base()

# Define a User table
class User(Base):
    __tablename__ = "users"  # Table name

    id = Column(Integer, primary_key=True, autoincrement=True)  # Primary key
    name = Column(String, nullable=False)  # Name column
    age = Column(Integer, nullable=False)  # Age column

# Create all tables in the database
Base.metadata.create_all(engine)
print("Tables created successfully")

Explanation

  • declarative_base(): Sets up a base class for defining ORM table models.
  • __tablename__: Specifies the name of the table in the database.
  • Base.metadata.create_all(engine): Creates all tables defined in the models.

Performing CRUD Operations

1. Inserting Records

Code:

from sqlalchemy.orm import Session

# Open a session
session = Session(bind=engine)

# Create a new user
new_user = User(name="Alice", age=25)

# Add the user to the session
session.add(new_user)

# Commit changes to save the user
session.commit()

print("User added successfully")

Explanation:

  • Session: Used to manage database transactions.
  • add(): Adds the new user object to the session.
  • commit(): Saves changes to the database.

2. Retrieving Records

Code:

# Query all users
users = session.query(User).all()

# Print details of each user
for user in users:
    print(f"ID: {user.id}, Name: {user.name}, Age: {user.age}")

Explanation:

    query(): Fetches records from the database.

    all(): Retrieves all records matching the query.


3. Updating Records

Code:

# Find a user by ID
user_to_update = session.query(User).filter_by(id=1).first()

# Update user details
if user_to_update:
    user_to_update.age = 30
    session.commit()
    print("User updated successfully")

Explanation

  • filter_by(): Filters records based on column values.
  • first(): Retrieves the first matching record.

4. Deleting Records

Code:

# Find a user by ID
user_to_delete = session.query(User).filter_by(id=1).first()

# Delete the user
if user_to_delete:
    session.delete(user_to_delete)
    session.commit()
    print("User deleted successfully")

Explanation

  • delete(): Removes the specified record from the database.

SQLAlchemy with Raw SQL in SQLite

For advanced use cases, you can execute raw SQL queries directly.

Code:

# Execute a raw SQL query
result = engine.execute("SELECT * FROM users")
for row in result:
    print(row)

Advantages of Using SQLAlchemy with SQLite

    1. ORM Simplifies Development: Eliminates the need to write raw SQL for common operations.

    2. Database Independence: Easily switch between SQLite and other databases by changing the engine configuration.

    3. Code Reusability: Python classes can be reused across projects, enhancing modularity.

    4. Error Handling: SQLAlchemy provides built-in methods to manage database connection errors.

Practical Guides to SQLite Snippets and Examples.



Follow us on Facebook and Twitter for latest update.