PyQt5中QSqlQuery的exec和exec_函数的使用问题

PyQt5的QSqlQuery类有两个函数,exec()和exec_(),每种函数又有两种参数类型,其函数原型是:

  exec(self, queryStr) -> bool
  exec(self) -> bool

  exec_(self, queryStr) -> bool
  exec_(self) -> bool

在PyQt5.11.2及其以后版本中,exec()和exec_()功能没有差别,使用exec()即可。

但是在PyQt5.11.2以前的版本中,不带参数的exec()函数不能执行由prepare()和bindValue()设置的带参数的SQL语句,而只能用exec_()函数执行。这是PyQt5.11.2以前版本的一个Bug,在PyQt5.11.2版本中被修正。

在Riverbank官网发布的 PyQt v5.11.2 Release News中对版本修改中有对此问题的说明

 These are the cumulative changes since v5.10.1.

    Added the missing QGuiApplication.inputMethod() method.
    Added the missing QGuiApplication.styleHints() method.
    Added the missing QSqlQuery.exec() overload for Python v3.

第一种带参数的函数exec(queryStr)或exec(queryStr)直接执行不带参数的SQL语句,在哪个PyQt5版本里都可以,如:

query=QSqlQuery(self.DB)
query.exec('''UPDATE employee SET Salary=3000 where Gender="女" ''')
query.exec_('''UPDATE employee SET Salary=3000 where Gender="女" ''')

第二种不带参数的函数exec()或exec_()执行由prepare()和bindValue()设置的带参数的SQL语句,如:

query=QSqlQuery(self.DB)
query.prepare('''UPDATE employee SET Salary=9000 where Gender=:Gender ''')
query.bindValue(":Gender","男")
query.exec()    #PyQt5.11.2 以前版本只能用exec_()

若是PyQt 5.11.2及其以后版本,这里用exec()或exec_()都可以,但若是PyQt 5.11.2以前的版本,则只能使用exec_()。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值