Python操作SQLite数据库

SQLite 是一种轻量级的数据库引擎,广泛用于嵌入式设备和小型应用程序。在Python中,SQLite 是一个流行的选择,因为它易于使用、快速、可靠,并且无需独立的服务器进程。本文将深入探讨如何使用 Python 操作 SQLite 数据库,包括创建数据库、表格、插入数据、查询数据等。

主要优点是sqlite在Python中使用通常是以文件的形式存在, 这减少了很多配置工作,主要用于小型项目的数据上传保存。

安装Sqlite3

在 Python 中,SQLite3 已经内置,无需额外安装。可以直接 import sqlite3 来使用它。

python 复制代码
import sqlite3

连接数据库

使用 connect() 函数连接到数据库,并返回一个 Connection 对象。

python 复制代码
conn = sqlite3.connect('example.db')

同样支持指定路径

python 复制代码
# 指定路径为 /path/to/your/database/example.db
conn = sqlite3.connect('/path/to/your/database/example.db')

创建表格

建表(如果已存在则报错)

python 复制代码
# 建表(如果已存在则报错)
create_table_sql = """
CREATE TABLE users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    age INTEGER
);
"""

conn.execute(create_table_sql)

建表(如果已存在则不做操作) 通常就使用这种方式

python 复制代码
# 建表(如果已存在则不做操作)
create_table_sql = """
CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    age INTEGER
);
"""

conn.execute(create_table_sql)

增删改查

python 复制代码
# 插入数据
def insert_user(name, age):
    sql = "INSERT INTO users (name, age) VALUES (?, ?)"
    conn.execute(sql, (name, age))
    conn.commit()


# 删除数据
def delete_user(user_id):
    sql = "DELETE FROM users WHERE id = ?"
    conn.execute(sql, (user_id,))
    conn.commit()


# 更新数据
def update_user(user_id, new_name, new_age):
    sql = "UPDATE users SET name = ?, age = ? WHERE id = ?"
    conn.execute(sql, (new_name, new_age, user_id))
    conn.commit()


# 查询多个数据(返回list)
def fetch_users():
    sql = "SELECT * FROM users"
    return conn.execute(sql).fetchall()

# 查询一个数据
def fetch_users():
    sql = "SELECT * FROM users"
    return conn.execute(sql).fetchone()

# 查询指定数目数据(返回list)
def fetch_users():
    sql = "SELECT * FROM users"
    return conn.execute(sql).fetchmany(10) # 获取10行

综合案例

python 复制代码
import sqlite3

# 连接到 SQLite 数据库,如果不存在将会创建一个新的数据库
conn = sqlite3.connect('example.db')

# 创建表的 SQL 语句
create_table_sql = """
CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    age INTEGER
);
"""

# 执行创建表的 SQL 语句
conn.execute(create_table_sql)


# 插入数据
def insert_user(name, age):
    sql = "INSERT INTO users (name, age) VALUES (?, ?)"
    conn.execute(sql, (name, age))
    conn.commit()


# 删除数据
def delete_user(user_id):
    sql = "DELETE FROM users WHERE id = ?"
    conn.execute(sql, (user_id,))
    conn.commit()


# 更新数据
def update_user(user_id, new_name, new_age):
    sql = "UPDATE users SET name = ?, age = ? WHERE id = ?"
    conn.execute(sql, (new_name, new_age, user_id))
    conn.commit()


# 查询数据
def fetch_users():
    sql = "SELECT * FROM users"
    return conn.execute(sql).fetchall()


# 插入一些示例数据
insert_user("Alice", 30)
insert_user("Bob", 25)

# 输出所有用户
print("All users:")
for user in fetch_users():
    print(user)

# 更新用户
update_user(1, "Alice Smith", 31)

# 输出所有用户
print("\nAll users after update:")
for user in fetch_users():
    print(user)

# 删除用户
delete_user(2)

# 输出所有用户
print("\nAll users after delete:")
for user in fetch_users():
    print(user)

# 关闭游标对象和数据库连接
conn.close()

运行结果

bash 复制代码
All users:
(1, 'Alice Smith', 31)
(2, 'Alice', 30)
(3, 'Bob', 25)

All users after update:
(1, 'Alice Smith', 31)
(2, 'Alice', 30)
(3, 'Bob', 25)

All users after delete:
(1, 'Alice Smith', 31)
(3, 'Bob', 25)
相关推荐
u0104058361 分钟前
企业微信第三方应用API对接的Java后端架构设计:解耦与可扩展性实践
java·数据库·企业微信
ascarl20103 分钟前
Oracle 12c 官方卸载工具 (Deinstall Tool) 标准流程
数据库·oracle
百炼成神 LV@菜哥3 分钟前
记GaussDB(for PostgreSQL)入门SQL操作
数据库·postgresql·gaussdb
之歆4 分钟前
Agent:链式工作流模式
数据库
子午5 分钟前
【2026原创】鱼类识别系统~Python+深度学习+CNN卷积神经网络算法+模型训练+图像识别
图像处理·python·深度学习·cnn
地理探险家6 分钟前
【YOLOv8实战】15组衣物类深度学习数据集分享|附加载+标签管理代码
人工智能·python·深度学习·yolo·模型训练·电商视觉
大学生毕业题目7 分钟前
毕业项目推荐:103-基于yolov8/yolov5/yolo11的皮肤癌检测识别系统(Python+卷积神经网络)
人工智能·python·yolo·目标检测·cnn·pyqt·皮肤癌检测
ai_top_trends8 分钟前
AI 生成 PPT 哪个好用?2026 年主流工具实测对比
人工智能·python
于初见月10 分钟前
Conda环境中的pip究竟指向哪里?
python·conda·pip
资深流水灯工程师17 分钟前
基于Python的Qt开发之Pyside6 QtSerialPort库的使用
python·qt