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_()。

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
PyQt5是一个用于创建图形用户界面(GUI)的Python库,它提供了丰富的功能和工具来开发跨平台的应用程序。PyQt5可以与各种数据库进行连接,包括MySQL、SQLite、PostgreSQL等。 要连接数据库,首先需要安装相应的数据库驱动程序。对于MySQL,可以使用PyMySQL或mysql-connector-python;对于SQLite,可以直接使用内置的sqlite3模块;对于PostgreSQL,可以使用psycopg2。 下面是一个使用PyQt5连接MySQL数据库的示例: 1. 首先,确保已经安装了PyQt5和PyMySQL库: ``` pip install PyQt5 pip install PyMySQL ``` 2. 导入必要的模块: ```python import sys from PyQt5.QtWidgets import QApplication, QMainWindow from PyQt5.QtSql import QSqlDatabase, QSqlQuery ``` 3. 创建一个连接到数据库的函数: ```python def createConnection(): db = QSqlDatabase.addDatabase('QMYSQL') db.setHostName('localhost') # 数据库主机名 db.setDatabaseName('mydatabase') # 数据库名称 db.setUserName('username') # 数据库用户名 db.setPassword('password') # 数据库密码 if db.open(): print('Connected to database') return True else: print('Failed to connect to database') return False ``` 4. 在主窗口调用连接函数: ```python class MainWindow(QMainWindow): def __init__(self): super().__init__() if createConnection(): # 连接成功后的操作 pass else: # 连接失败后的操作 pass if __name__ == '__main__': app = QApplication(sys.argv) mainWindow = MainWindow() mainWindow.show() sys.exit(app.exec_()) ``` 这是一个简单的示例,你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值