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

相关推荐
海南java第二人7 小时前
Nebula Graph 实战:基于图数据库存储 CMDB 实体关系
数据库·图数据库·nebula
曹牧8 小时前
oracle:“not all variables bound”
数据库·oracle
数据库百宝箱8 小时前
Oracle RMAN Image Copy 本地恢复
数据库·oracle
zuYM4g7Dp9 小时前
NoSql数据库设计心得
数据库·nosql
睡不醒男孩03082311 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
cmes_love11 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
swordbob12 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q12 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
十五年专注C++开发12 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
数据库小学妹12 小时前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai