PyQt5->QSqlTableModel->setFilter 无结果

MotionCtrl_Seven 2018-06-29 05:32:05
请教各位大牛:

我用一个TableView来显示从数据库中的数据,然后想通过QSqlTableModel->setFilter来过滤要显示的内容,初始化代码如下:




self.db=QSqlDatabase.addDatabase("QSQLITE")

self.paramModel = QSqlRelationalTableModel(self, self.db)
self.tbParam.setModel(self.paramModel)
self.tbParam.setItemDelegate(QSqlRelationalDelegate(self.tbParam))


然后在控件的改变事件中更新Filter (其中有一列为‘Menu’数据类型为SMALLINT):

@pyqtSlot(int)
def on_spinMenu_valueChanged(self, p0):
"""
Slot documentation goes here.

@param p0 DESCRIPTION
@type int
"""

self.paramModel.setFilter(self.tr("Menu>%d"%p0))
self.paramModel.select()



但实际上程序并不能如预期地实现,只要setFilter的内容不为空,就不显示任何内容,请教各们大牛问题在哪里?

...全文
643 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
MotionCtrl_Seven 2018-06-29
  • 打赏
  • 举报
回复
原来是因为用了QSqlRelationalTableModel,设定Relationship的时候如果本表中一个列关联到本表中另外一个列就会出现这种情况!
给大家一个参考

16,215

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧