PyQt中使⽤QtSql连接MySql数据库的⽅法
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 = ("select count(*) from `user`;")
if not isSuccess:
print(query.lastError().text())
():
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 进⾏数据绑定
创建数据模型
setTable() 是指定当前 model 关联的是哪张表。
setEditStrategy() 是设置修改模型。其参数是个枚举,共有3个值。
OnFieldChange :模型的任何将⽴即更新到数据库。
OnRowChange :当⽤户选择不同的⾏时,将应⽤对⾏(改动过的⾏)的更改。
OnManualSubmit :所有更改将在模型中缓存,直到 submitAll() 或者 revertAll() 被调⽤。
select() 是从关联的表中获取数据,默认是获取全部数据。
关联 QtTableView
self.tableView.del)
将上⽂创建的 model 设置给 tableView 即可在 tableView 上展⽰表中数据。plsql developer可以连接mysql吗
显⽰的列名默认是数据库中表的列表,可以通过下⽅代码⾃定义列名。
使⽤ QSqlTableModel 会返回所有列,如果有列不希望展⽰出来,可以通过下⽅代码隐藏列。
self.tableView.setColumnHidden(3, True)
到此这篇关于PyQt中使⽤QtSql连接MySql数据库的⽅法的⽂章就介绍到这了,更多相关PyQt QtSql连接MySql内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论