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 源码文件和数据库交互时编码一致。

相关推荐
OpsEye2 小时前
数据库连接池爆了,这3个命令能救你一次
运维·数据库·后端
csdn小瓯2 小时前
PostgreSQL迁移实战:从SQLite到生产级数据库的平滑演进
数据库·postgresql·sqlite
夜白宋2 小时前
【JVM深入】一、基本内容
jvm
码云骑士3 小时前
Redis 入门实战:从 NoSQL 概念到安装与基础操作详解(一)
数据库·redis·缓存
YL200404263 小时前
MySQL-进阶篇-锁
数据库·mysql
爱喝水的鱼丶3 小时前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧
运维·数据库·学习·性能优化·sap·abap·开发交流
SelectDB技术团队3 小时前
PB 级自动驾驶数据秒级检索:Apache Doris 统一多模态数据平台实践
数据库·人工智能·自动驾驶·apache doris·selectdb
爱编程的小新☆3 小时前
LangGraph4j工作流框架
前端·数据库·ai·langchain·langgraph4j
vKd0Ff21L3 小时前
如何在Dev-C++中设置TDM-GCC为默认编译器第九十一篇
java·jvm·c++