Pyside6(PyQT5)中的QTableView与QSqlQueryModel、QSqlTableModel的联合使用

news2025/1/24 14:17:33

        QTableView 是QT的一个强大的表视图部件,可以与模型结合使用以显示和编辑数据。QSqlQueryModel、QSqlTableModel 都是用于与 SQL 数据库交互的模型,将二者与QTableView结合使用可以轻松地展示和编辑数据库的数据。


QSqlQueryModel的简单应用

import sys
from PySide6.QtWidgets import QApplication, QMainWindow, QTableView
from PySide6.QtSql import QSqlDatabase, QSqlQueryModel

# 创建应用程序实例
app = QApplication(sys.argv)

# 连接到SQLite数据库
# 假设脚本同目录下的数据库文件名为example.db,表名为example_table
db = QSqlDatabase.addDatabase('QSQLITE')   # 指定使用的数据库驱动为SQLite
db.setDatabaseName('example.db')  # 设置数据库文件路径
if not db.open():  # 如果数据库打开失败,打印错误信息
    print("无法连接到数据库")
    sys.exit(1)

# 创建数据模型
model = QSqlQueryModel()
model.setQuery("SELECT * FROM users")  # 执行SQL查询

# 创建主窗口
window = QMainWindow()
window.setWindowTitle("SQLite数据展示")

# 创建表格视图,并设置模型
table_view = QTableView()
table_view.setModel(model)  # 将查询模型设置给表格视图
window.setCentralWidget(table_view)  # 将表格视图设置为主窗口的中心部件

# 显示窗口
window.show()

# 运行应用程序循环
sys.exit(app.exec())

         上面的这个代码是查询数据库并将结果用表格方式展示的基本应用,在这个代码中,使用了QSqlQueryModel模型,表格的数据只是用于展示,并不能在表格中对数据进行编辑和修改。


QSqlTableModel的简单应用

import sys
from PySide6.QtWidgets import QApplication, QMainWindow, QTableView
from PySide6.QtSql import QSqlDatabase, QSqlTableModel
from PySide6.QtCore import Qt

# 创建应用程序实例
app = QApplication(sys.argv)

# 设置数据库
db = QSqlDatabase.addDatabase("QSQLITE")   # 设置数据库类型
db.setDatabaseName("project_db.db")        # 设置数据库名称
if not db.open():
    print("无法打开数据库")
    sys.exit(1)

# 创建模型
model = QSqlTableModel()   # 创建模型
model.setTable("users")    # 设置模型与数据表关联

# 设置模型的编辑策略(可选)
model.setEditStrategy(QSqlTableModel.OnFieldChange)  # 数据更改后立即写入数据库

# 选择表中的所有记录
model.select()             

# 创建主窗口
window = QMainWindow()
window.setWindowTitle("SQLite数据展示")

# 创建表格视图,并设置模型
table_view = QTableView()
table_view.setModel(model)  # 将查询模型设置给表格视图
window.setCentralWidget(table_view)  # 将表格视图设置为主窗口的中心部件

# 可选:设置列标题
# model.setHeaderData(0, Qt.Horizontal, "ID")
# model.setHeaderData(1, Qt.Horizontal, "name")
# model.setHeaderData(2, Qt.Horizontal, "passwd")

# 显示窗口
window.show()

# 运行应用程序循环
sys.exit(app.exec())


        这段代码使用了QSqlTableModel类来创建一个数据库模型。QSqlTableModel是一个高层次的接口,用于处理单个数据库表,并且可以与视图(如QTableView)一起使用来显示和编辑表中的数据。当我们在界面显示的表格中将管理员密码修改为“123”,数据库中的内容同步得到了更新。 


QSqlQueryModel与QSqlTableModel的区别

• 功能定位

• QSqlQueryModel  :

        • 功能:用于执行 SQL 查询语句,并将查询结果以模型的形式展示。

        • 特点:它是一个只读模型,主要用于显示查询结果。如果需要修改数据,必须手动执行 SQL 更新语句。

        • 适用场景:适合用于执行复杂的 SQL 查询,并将结果展示在视图中(如   QTableView   或   QListView  )。例如,联合查询、分组查询等场景。

• QSqlTableModel  :

        • 功能:提供了一个可编辑的模型,用于操作数据库表中的数据。

        • 特点:支持对表数据的增、删、改、查操作,可以直接通过模型接口修改数据,而无需手动编写 SQL 语句。

        • 适用场景:适合用于直接操作单个数据库表的场景,尤其是需要对表数据进行编辑的应用。

•数据操作方式

•  QSqlQueryModel  :

        • 查询:通过执行 SQL 查询语句获取数据。

        • 修改:不支持直接通过模型修改数据。如果需要修改数据,必须手动执行 SQL 更新语句。

• QSqlTableModel  :

        • 查询:自动加载整个表的数据,也可以通过设置过滤条件来限制显示的数据。

        • 修改:支持通过模型接口直接修改数据,例如插入、删除、更新行。

灵活性与易用性

• QSqlQueryModel  :

        • 优点:灵活性高,可以执行任意复杂的 SQL 查询语句。

        • 缺点:不支持直接修改数据,需要手动编写 SQL 更新语句。

• QSqlTableModel  :

        • 优点:操作简单,支持直接通过模型接口修改数据,适合对单个表的操作。

        • 缺点:只能操作单个表,不支持复杂的 SQL 查询(如联合查询)。

 • 性能

• QSqlQueryModel  :

        • 性能:查询结果直接从 SQL 查询语句生成,性能较高,尤其是对于复杂的查询。

• QSqlTableModel  :

        • 性能:加载整个表的数据,可能会在数据量较大时影响性能。但如果设置了过滤条件,可以限制加载的数据量。

适用场景总结

• QSqlQueryModel  :

        • 适用于需要执行复杂查询(如联合查询、分组查询)的场景。

        • 适用于只读数据展示的场景。

• QSqlTableModel  :

        • 适用于对单个表进行增、删、改、查操作的场景。

        • 适用于需要简单数据操作且对性能要求不高的场景。


QSqlQueryModel的另一个范例

这个范例中设置了筛选条件,只显示符合条件的部分数据

from PySide6.QtSql import QSqlQueryModel, QSqlDatabase
from PySide6.QtWidgets import QApplication, QTableView

# 定义create_connection函数,用于创建数据库连接
def create_connection():
    # 添加一个SQLite数据库驱动
    db = QSqlDatabase.addDatabase('QSQLITE')
    # 设置数据库名称为example.db
    db.setDatabaseName('example.db')
    # 尝试打开数据库连接
    if not db.open():
        # 如果打开失败,打印错误信息并返回False
        print("Unable to open database")
        return False
    # 如果打开成功,返回True
    return True

def main(): 
    app = QApplication([])

    # 调用create_connection函数,如果返回False则终止程序
    if not create_connection():
        return

    # 创建一个QSqlQueryModel实例,用于执行SQL查询并将结果存储在模型中
    model = QSqlQueryModel()
    # 设置模型的查询语句,这里选择年龄大于30的员工记录
    model.setQuery("SELECT * FROM employees WHERE age > 30")

    # 创建一个QTableView实例,用于显示模型中的数据
    view = QTableView()
    # 将模型设置到视图中
    view.setModel(model)
    # 显示视图
    view.show()

    # 进入Qt应用程序的事件循环
    app.exec()

# 如果当前脚本是直接运行的,则调用main函数
if __name__ == "__main__":
    main()


QSqlTableModel的另一个范例

这个范例中同样设置了筛选条件,只显示符合条件的部分数据

from PySide6.QtSql import QSqlTableModel, QSqlDatabase
from PySide6.QtWidgets import QApplication, QTableView

# 定义一个函数用于创建数据库连接
def create_connection():
    # 添加一个SQLite数据库驱动
    db = QSqlDatabase.addDatabase('QSQLITE')
    # 设置数据库文件的名称
    db.setDatabaseName('example.db')
    # 尝试打开数据库连接
    if not db.open():
        # 如果打开失败,打印错误信息并返回False
        print("Unable to open database")
        return False
    # 如果打开成功,返回True
    return True

# 主函数
def main():
    app = QApplication([])

    # 调用函数创建数据库连接,如果失败则退出程序
    if not create_connection():
        return

    # 创建一个QSqlTableModel实例,用于操作数据库中的数据
    model = QSqlTableModel()
    # 设置操作的表名为"employees"
    model.setTable("employees")
    # 设置过滤条件,只显示年龄大于30的记录
    model.setFilter("age > 30")
    # 执行查询操作
    model.select()

    # 创建一个QTableView实例,用于显示数据
    view = QTableView()
    # 将数据模型设置到视图上
    view.setModel(model)
    # 显示视图
    view.show()

    # 进入Qt应用程序的事件循环
    app.exec_()

# 如果当前脚本是主程序,则执行main函数
if __name__ == "__main__":
    main()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2281458.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言文件操作:标准库与系统调用实践

目录 1、C语言标准库文件操作 1.1.题目要求: 1.2.函数讲解: fopen 函数原型 参数 常用的打开模式 返回值 fwrite函数 函数原型 参数 返回值 注意事项 fseek函数 函数原型 参数 返回值 fread函数 函数原型 参数 返回值 fclose 函数…

【2024年华为OD机试】 (C卷,100分)- 多段线数据压缩(JavaScriptJava PythonC/C++)

一、问题描述 问题描述 给定一个多线段的坐标列表,每个坐标由行号和列号表示。多线段的走向只能是水平、竖直或斜向45度。输入数据包含冗余的坐标点,要求输出最简化的坐标列表,仅保留起点、拐点和终点。 输入描述 输入数据为多线段的坐标…

状态模式——C++实现

目录 1. 状态模式简介 2. 代码示例 3. 单例状态对象 4. 状态模式与策略模式的辨析 1. 状态模式简介 状态模式是一种行为型模式。 状态模式的定义:状态模式允许对象在内部状态改变时改变它的行为,对象看起来好像修改了它的类。 通俗的说就是一个对象…

数据库SQLite和SCADA DIAView应用教程

课程简介 此系列课程大纲主要包含七个课时。主要使用到的开发工具有:SQLite studio 和 SCADA DIAView。详细的可成内容大概如下: 1、SQLite 可视化管理工具SQLite Studio :打开数据库和查询数据;查看视频 2、创建6个变量&#x…

java开发,IDEA转战VSCODE配置(mac)

一、基本java开发环境配置 前提:已经安装了jdk、maven、vscode,且配置了环境变量 1、安装java相关的插件 2、安装spring相关的插件 3、vscode配置maven环境 打开 VsCode -> 首选项 -> 设置,也可以在setting.json文件中直接编辑&…

python爬虫的学习流程(1-前提准备)

这里主要记录一下我的python爬虫初级的学习的流程 1.python爬虫入门实战课 什么是爬虫?众说纷纭,我们引用维基百科上对网络爬虫的介绍: 网络爬虫(英语:Web crawler),也叫网络蜘蛛(…

数据结构初阶之双向链表的介绍与双向链表的实现

一、概念与结构 带头双向循环链表 next :指向下一个结点(后继结点) prev :指向前一个结点(前驱结点) 二、实现双向链表 项目创建的时候,要创建一个头文件(.h)List.h …

CICD集合(六):Jenkins配置Editable Email Notification

CICD集合(六):Jenkins配置Editable Email Notification 1、系统配置 1.1、Jenkins Location 1.2、邮件通知 1、SMTP服务器:imap.exmail.qq.com (因qq企业邮箱) 2、邮箱后缀:@xxx.com 3、勾选:使用SMTP认证 用户名:

Golang 中除了加锁还有哪些安全读写共享变量的方式?

Golang 中除了加锁还有哪些安全读写共享变量的方式? 在 Golang 中,除了使用 Mutex 锁来保护共享变量外,还可以通过 Channel 和 原子性操作 来实现安全读写共享变量。 1. 使用 Channel 原理 Channel 是 Golang 中用于 Goroutine 之间通信的…

应用层协议 HTTP 讲解实战:从0实现HTTP 服务器

🌈 个人主页:Zfox_ 🔥 系列专栏:Linux 目录 一:🔥 HTTP 协议 🦋 认识 URL🦋 urlencode 和 urldecode 二:🔥 HTTP 协议请求与响应格式 🦋 HTTP 请求…

F/V/F/I频率脉冲信号转换器

F/V/F/I频率脉冲信号转换器 概述:捷晟达科技的JSD TFA-1001系列是一进一出频率脉冲信号转换器(F/V转换器),该频率转换器是将频率脉冲信号(方波、正弦波、锯齿波)转换成国际标准的模拟量电压(电流)信号,并远距离无失真传送到控制室(如:PLC,DCS,AD,PC采集系统)产品的输…

Windows的docker中安装gitlab

一.Windows的docker中安装gitlab 1.通过阿里云拉取镜像 docker pull registry.cn-hangzhou.aliyuncs.com/lab99/gitlab-ce-zh 2.在本地创建备份数据的目录 mkdir -p D:home/software/gitlab/etc mkdir -p D:home/software/gitlab/logs mkdir -p D:home/software/gitlab/dat…

【Linux】理解Linux中一切皆文件、缓冲区、ext2文件系统、软硬链接

⭐️个人主页:小羊 ⭐️所属专栏:Linux 很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~ 目录 1、如何理解在Linux中一切皆文件?1.1 概述1.2 文件类型1.3 优势 2、缓冲区2.1 为什么要引入缓冲区?2.2 缓…

在Docker 容器中安装 Oracle 19c

在 Docker 容器中安装 Oracle 19c 是可行的,但它相较于其他数据库(如 MySQL、PostgreSQL 等)会复杂一些,因为 Oracle 数据库有一些特定的要求,如操作系统和库的依赖,以及许可证问题。 不过,Ora…

【数据库】详解MySQL数据库中的事务与锁

目录 1.数据库事务 1.1.事务的四大特性 1.2.事务开启的方式 1.3.读一致性问题及其解决 2.MVCC解决读一致性问题原理 2.1.MVCC概念 2.2.准备环境 3.MySQL中的锁 3.1.行锁之共享锁 3.2.行锁之排它锁 1.数据库事务 数据库事务(Transaction)是一种…

springboot 配置redis

环境配置 springboot3.4 redis5.0.14 redis准备参考下面文章 window下安装redis以及启动 redis客户端安装 引入依赖 <!-- 集成redis依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-…

EEG代码实践:diffusion EEG——扩散模型生成EEG信号

2024/1/22&#xff1a; 原始EEG信号的生成说实话一直做不到让人满意的水平&#xff0c;之前做的MIEEG复现也迟迟没有调整到自己想要的程度&#xff0c;与论文中的效果还是有些差距。改换思路使用离散小波变换&#xff0c;用变换之后的信号做生成任务则好了许多。从大二开始一直…

Banana Pi BPI-RV2 开发板矽昌通信 RISC-V路由芯片SF21H8898优势亮点

Banana Pi BPI-RV3开源路由器 1. 8898芯片具备强大的网络加速硬件性能&#xff0c;能够在小字节报文条件下实现高效数据转发&#xff1a;  单WAN口性能&#xff1a;支持 64 字节报文单向转发速率达到 2.5 Gbps&#xff0c;双向转发速率为 5 Gbps。双WAN口性能&#xff1a;支…

光谱相机在智能冰箱的应用原理与优势

食品新鲜度检测 详细可点击查看汇能感知团队实验报告&#xff1a;高光谱成像技术检测食物新鲜度 检测原理&#xff1a;不同新鲜程度的食品&#xff0c;其化学成分和结构会有所不同&#xff0c;在光谱下的反射、吸收等特性也存在差异。例如新鲜肉类和蔬菜中的水分、蛋白质、叶…

xxljob执行失败,xxl-job remoting error(sl.nts.com), for url : http://xxxxxxxxxx/run

问题 项目部署后&#xff0c;发现xxljob没有正常工作&#xff0c;报错 尝试解决&#xff1a; &#xff08;1&#xff09;检查xxljob配置&#xff08;无问题&#xff09; &#xff08;2&#xff09;检查服务器hosts文件域名配置&#xff08;依旧无问题&#xff09; 各种能检查…