PyQt中使用QtSql连接MySql数据库的方法


Posted in Python onJuly 28, 2020

PyQt 有内置的数据库连接类 QtSql 。

在使用 PyQt 连接 MySql 展示数据时,如果明确所有数据库操作都与 Qt 窗口有关,且不涉及复杂的数据操作,则可以使用内置的 QtSql 类。不需要安装额外的数据库类,且能更加便利的与 QtTableView 等 Qt 控件进行数据交互。

初始化

db = QtSql.QSqlDatabase.addDatabase('QMYSQL')
db.setHostName('localhost')
db.setDatabaseName('dev')
db.setUserName('root')
db.setPassword('123')
db.open()

QMYSQL 代表连接 MySql 数据库,可以通过 QtSql.QSqlDatabase.drivers() 来查询当前版本 PyQt 所支持的数据库类型。

数据库连接创建后不需要长期持有 db ,连接会一直存在,直到应用程序关闭或调用 removeDatabase() 为止才会关闭。

操作数据库

一个基础的查询命令如下:

query = QSqlQuery()
isSuccess = query.exec("select count(*) from `user`;")
if not isSuccess:
  print(query.lastError().text())
if query.next():
  count = query.value(0)

创建查询对象

创建 QSqlQuery 对象。此处不需要额外参数,会使用上方初始化时连接的数据库及 database 。

执行命令

调用 exec() 方法执行查询命令。传递参数为查询语句。该方法会返回1个布尔值表示查询是否成功,失败时可以通过调用 lastError().text() 来获取失败原因。

获取查询数据

QSqlQuery 提供了 next() 、 prev() 、 first() 、 last() 和 seek() 等方法在返回的记录中进行导航,可以很容易的进行移动。但需要注意的是, exec() 刚执行结束后是定位在1个无效记录上,必须先导航到1个有效的记录上才能获取数据。

可以通过 isValid() 来判断当前是否处在一条无效的记录上。

另外 next() 、 prev() 、 first() 、 last() 和 seek() 等方法同样有布尔返回值,当导航向的记录无效时会返回 False ,可以通过返回值来辅助判断是否已经查询超出了边界值。

与 QtTableView 进行数据绑定

创建数据模型

self.model = QtSql.QSqlTableModel(self)
self.model.setTable('user')
self.model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
self.model.select()

setTable() 是指定当前 model 关联的是哪张表。

setEditStrategy() 是设置修改模型。其参数是个枚举,共有3个值。

  • OnFieldChange :模型的任何将立即更新到数据库。
  • OnRowChange :当用户选择不同的行时,将应用对行(改动过的行)的更改。
  • OnManualSubmit :所有更改将在模型中缓存,直到 submitAll() 或者 revertAll() 被调用。

select() 是从关联的表中获取数据,默认是获取全部数据。

关联 QtTableView

self.tableView.setModel(self.model)

将上文创建的 model 设置给 tableView 即可在 tableView 上展示表中数据。

显示的列名默认是数据库中表的列表,可以通过下方代码自定义列名。

self.model.setHeaderData(0, QtCore.Qt.Horizontal, 'ID')

使用 QSqlTableModel 会返回所有列,如果有列不希望展示出来,可以通过下方代码隐藏列。

self.tableView.setColumnHidden(3, True)

到此这篇关于PyQt中使用QtSql连接MySql数据库的方法的文章就介绍到这了,更多相关PyQt  QtSql连接MySql内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python分割和拼接字符串
Nov 01 Python
python中使用百度音乐搜索的api下载指定歌曲的lrc歌词
Jul 18 Python
python实现机器人行走效果
Jan 29 Python
python3.4控制用户输入与输出的方法
Oct 17 Python
python 批量解压压缩文件的实例代码
Jun 27 Python
python3.6 如何将list存入txt后再读出list的方法
Jul 02 Python
Django 创建/删除用户的示例代码
Jul 24 Python
Python搭建HTTP服务过程图解
Dec 14 Python
基于django和dropzone.js实现上传文件
Nov 24 Python
Ubuntu20下的Django安装的方法步骤
Jan 24 Python
Django如何与Ajax交互
Apr 29 Python
PyTorch 如何检查模型梯度是否可导
Jun 05 Python
pycharm全局搜索的具体步骤
Jul 28 #Python
Django model重写save方法及update踩坑详解
Jul 27 #Python
matplotlib 画双轴子图无法显示x轴的解决方法
Jul 27 #Python
虚拟机下载python是否需要联网
Jul 27 #Python
详解在Python中使用Torchmoji将文本转换为表情符号
Jul 27 #Python
基于python实现操作git过程代码解析
Jul 27 #Python
2021年的Python 时间轴和即将推出的功能详解
Jul 27 #Python
You might like
2020年4月新番动漫目录 官方宣布4月播出的作品一览
2020/03/08 日漫
PHP中调用JAVA
2006/10/09 PHP
深入理解用mysql_fetch_row()以数组的形式返回查询结果
2013/06/05 PHP
20个2014年最优秀的PHP框架回顾
2014/10/22 PHP
phpmailer简单发送邮件的方法(附phpmailer源码下载)
2016/06/13 PHP
简述php环境搭建与配置
2016/12/05 PHP
ecshop添加菜单及权限分配问题
2017/11/21 PHP
Ucren Virtual Desktop V2.0
2006/11/07 Javascript
Jquery AJAX 框架的使用方法
2009/11/03 Javascript
js 完美图片新闻轮转效果,腾讯大粤网首页图片轮转改造而来
2011/11/21 Javascript
js精度溢出解决方案
2012/12/02 Javascript
js实现checkbox全选和反选示例
2014/05/01 Javascript
nodejs之请求路由概述
2014/07/05 NodeJs
分享20款美化网站的 jQuery Lightbox 灯箱插件
2014/10/10 Javascript
JQuery基础语法小结
2015/02/27 Javascript
浅谈Sizzle的“编译原理”
2015/04/14 Javascript
jQuery实现首页图片淡入淡出效果的方法
2015/06/10 Javascript
谈谈impress.js初步理解
2015/09/09 Javascript
javascript设计简单的秒表计时器
2020/09/05 Javascript
js 截取或者替换字符串中的数字实现方法
2016/06/13 Javascript
jQuery实现分页功能(含ajax请求、后台数据、附完整demo)
2017/04/03 jQuery
JavaScript中使用Async实现异步控制
2017/08/15 Javascript
js监听html页面的上下滚动事件方法
2018/09/11 Javascript
Vue 刷新当前路由的实现代码
2019/09/26 Javascript
原生js实现俄罗斯方块
2020/10/20 Javascript
python实现的希尔排序算法实例
2015/07/01 Python
python 实时得到cpu和内存的使用情况方法
2018/06/11 Python
Python完成哈夫曼树编码过程及原理详解
2019/07/29 Python
Python OpenCV图像指定区域裁剪的实现
2019/10/30 Python
python垃圾回收机制(GC)原理解析
2019/12/30 Python
你的自行车健身专家:FaFit24
2016/11/16 全球购物
四年的个人工作自我评价
2013/12/10 职场文书
2015年社区卫生工作总结
2015/04/21 职场文书
永不妥协观后感
2015/06/10 职场文书
超级礼物观后感
2015/06/15 职场文书
启迪人心的励志语录:脾气永远不要大于本事
2020/01/02 职场文书