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 06 Python
Python字典操作简明总结
Apr 13 Python
python使用PyGame播放Midi和Mp3文件的方法
Apr 24 Python
Python中使用Beautiful Soup库的超详细教程
Apr 30 Python
python 递归遍历文件夹,并打印满足条件的文件路径实例
Aug 30 Python
python+pygame简单画板实现代码实例
Dec 13 Python
python实现求两个字符串的最长公共子串方法
Jul 20 Python
python 整数越界问题详解
Jun 27 Python
关于Python-faker的函数效果一览
Nov 28 Python
python实现替换word中的关键文字(使用通配符)
Feb 13 Python
基于python计算滚动方差(标准差)talib和pd.rolling函数差异详解
Jun 08 Python
Django正则URL匹配实现流程解析
Nov 13 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
用PHP实现的生成静态HTML速度快类库
2007/03/31 PHP
PHP sprintf() 函数的应用(定义和用法)
2012/06/29 PHP
基于PHP读取csv文件内容的详解
2013/06/18 PHP
PHP实现把文本中的URL转换为链接的auolink()函数分享
2014/07/29 PHP
PHP会话处理的10个函数
2015/08/11 PHP
Apache启动报错No space left on device: AH00023该怎么解决
2015/10/16 PHP
详解PHP中cookie和session的区别及cookie和session用法小结
2016/06/12 PHP
PHP中关于php.ini参数优化详解
2020/02/28 PHP
Iframe thickbox2.0使用的方法
2009/03/05 Javascript
JavaScript 获取当前时间戳的代码
2010/08/05 Javascript
原生JavaScript实现连连看游戏(附源码)
2013/11/05 Javascript
js禁止回车提交表单的示例代码
2013/12/23 Javascript
jQuery实现友好的轮播图片特效
2015/01/12 Javascript
在JavaScript中调用Java类和接口的方法
2016/09/07 Javascript
Javascript 函数的四种调用模式
2016/11/05 Javascript
nodejs实现OAuth2.0授权服务认证
2017/12/27 NodeJs
JavaScrip数组去重操作实例小结
2019/06/20 Javascript
使用Vue CLI创建typescript项目的方法
2019/08/09 Javascript
vue框架制作购物车小球动画效果实例代码
2019/09/26 Javascript
为react组件库添加typescript类型提示的方法
2020/06/15 Javascript
JavaScript实现下拉列表
2021/01/20 Javascript
[51:44]2018DOTA2亚洲邀请赛 4.3 突围赛 Optic vs iG 第二场
2018/04/04 DOTA
python3使用urllib示例取googletranslate(谷歌翻译)
2014/01/23 Python
如何在Django中添加没有微秒的 DateTimeField 属性详解
2019/01/30 Python
python try 异常处理(史上最全)
2019/03/07 Python
Pandas操作CSV文件的读写实现方法
2019/11/13 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
2020/06/08 Python
如何利用python之wxpy模块玩转微信
2020/08/17 Python
python UDF 实现对csv批量md5加密操作
2021/01/01 Python
CSS3 分类菜单效果
2019/05/27 HTML / CSS
中国跨境海淘网站:考拉海购
2016/08/01 全球购物
递归计算如下递归函数的值(斐波拉契)
2012/02/04 面试题
会计辞职信范文
2014/01/15 职场文书
大学学习生活感言
2014/01/18 职场文书
《傅雷家书》教学反思
2014/04/20 职场文书
巾帼建功标兵先进事迹材料
2016/02/29 职场文书