qt中使用QSqlite数据库时,使用QSqlTableModel不显示数据的情况

今天写代码的时候,在页面上使用了QSqlTableModel来显示数据库中的数据,改动一些无关紧要的代码之后,莫名其妙不显示数据了,最终发现根本原因是使用QSqlTableModel时,需要先打开数据库的连接

不显示数据库中的数据
显示数据

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt,可以使用QTableView控件来显示数据库数据。要使用委托更改数据并将更改保存到数据库,可以使用QItemDelegate类。 以下是一个简单的示例代码,说明如何使用QTableView和QItemDelegate来显示和编辑数据库数据: ```python # 导入必要的模块 from PyQt5.QtCore import Qt, QModelIndex from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QTableView, QPushButton, QMessageBox, QItemDelegate from PyQt5.QtSql import QSqlDatabase, QSqlTableModel # 定义一个委托类,用于编辑表格数据 class MyDelegate(QItemDelegate): def createEditor(self, parent, option, index): # 创建一个QLineEdit控件,用于编辑数据 editor = QLineEdit(parent) editor.setFrame(False) editor.setAlignment(Qt.AlignCenter) return editor def setEditorData(self, editor, index): # 将表格数据显示在QLineEdit控件 value = index.model().data(index, Qt.DisplayRole) editor.setText(str(value)) def setModelData(self, editor, model, index): # 将QLineEdit控件数据保存到数据库 value = editor.text() model.setData(index, value, Qt.EditRole) model.submitAll() # 定义一个窗口类,用于显示表格和按钮 class MyWindow(QWidget): def __init__(self): super().__init__() # 连接数据库 db = QSqlDatabase.addDatabase('QSQLITE') db.setDatabaseName('mydatabase.db') db.open() # 创建一个QTableView控件,并设置委托 self.tableview = QTableView(self) delegate = MyDelegate(self.tableview) self.tableview.setItemDelegate(delegate) # 创建一个QSqlTableModel,并设置数据源 self.model = QSqlTableModel(self) self.model.setTable('mytable') self.model.select() # 将QSqlTableModel绑定到QTableView控件 self.tableview.setModel(self.model) # 创建一个保存按钮,用于保存更改 self.save_button = QPushButton('保存', self) self.save_button.clicked.connect(self.save_data) # 创建一个垂直布局,并将QTableView和QPushButton添加到其 layout = QVBoxLayout(self) layout.addWidget(self.tableview) layout.addWidget(self.save_button) def save_data(self): # 提交所有更改,并显示保存成功的消息框 if self.model.submitAll(): QMessageBox.information(self, '保存成功', '数据已保存!') # 创建一个应用程序,并显示窗口 app = QApplication([]) window = MyWindow() window.show() app.exec_() ``` 在这个示例代码QTableView控件用于显示数据库数据,QItemDelegate用于编辑表格数据,并将更改保存到数据库。在窗口还添加了一个保存按钮,用于提交所有更改并显示保存成功的消息框。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值