PySide6 数据库操作深度实测:从 SQLite 连接到增删改查避坑指南

PySide6 数据库操作深度实测:从 SQLite 连接到增删改查避坑指南

桌面应用常常需要本地数据存储,SQLite 因其轻量、免配置的特性成为首选。PySide6 的 QtSql 模块为我们提供了非常方便的数据库操作接口,尤其是 QSqlTableModel,可以实现数据与界面控件的"零代码"绑定。

1. 建立数据库连接

在使用任何 SQL 类之前,必须先添加并打开数据库。

python 复制代码
from PySide6.QtSql import QSqlDatabase, QSqlQuery, QSqlTableModel
from PySide6.QtWidgets import QMessageBox

def init_db():
    db = QSqlDatabase.addDatabase("QSQLITE")
    db.setDatabaseName("my_data.db")
    if not db.open():
        QMessageBox.critical(None, "数据库错误", f"无法打开数据库: {db.lastError().text()}")
        return False
    return True
2. 神器 QSqlTableModel:免写 SQL 的增删改查

如果你想把数据库表直接显示在 QTableView 中,并且支持用户直接双击修改,QSqlTableModel 是最佳选择。

python 复制代码
# 初始化模型
self.model = QSqlTableModel()
self.model.setTable("users")  # 绑定数据库中的 users 表
self.model.setEditStrategy(QSqlTableModel.OnFieldChange) # 字段修改后自动同步到数据库
self.model.select() # 必须调用 select 才会加载数据

# 绑定到界面表格
self.tableView.setModel(self.model)

增删改操作实战:

  • 增加一行
  • 删除选中行
3. 使用 QSqlQuery 执行原生 SQL

对于复杂的查询(如多表联查、聚合统计),QSqlTableModel 就不够用了,这时需要回归原生的 SQL 语句。

python 复制代码
query = QSqlQuery()
# 插入数据
query.exec("INSERT INTO users (name, age) VALUES ('李四', 25)")
# 查询数据
if query.exec("SELECT * FROM users WHERE age > 20"):
    while query.next():
        name = query.value(1) # 获取第1列的值
        print(f"查询到用户: {name}")
4. 避坑指南
  • 连接名冲突addDatabase 默认连接名为 qt_sql_default_connection。如果你在多处调用,会覆盖之前的连接。建议给连接起个唯一的名字,如 addDatabase("QSQLITE", "my_conn_1")
  • 界面卡顿QSqlTableModelselect() 操作是同步的。如果表中有几十万条数据,主线程会卡死。对于大数据量,建议配合分页查询,或者在子线程中使用 QSqlQuery 读取数据后通过信号传回主线程。
  • 中文乱码:SQLite 默认使用 UTF-8,确保你的 Python 源码文件和数据库交互时编码一致。

相关推荐
jiayou641 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB5 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶5 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构