PyQt 中使用 QtSql 连接 MySql 数据库

时间:2020-7-28 作者:admin

前言

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个值。

  1. OnFieldChange:模型的任何将立即更新到数据库。
  2. OnRowChange:当用户选择不同的行时,将应用对行(改动过的行)的更改。
  3. 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)
声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。