QSqlRelationalTableModel 只填充前 256 条记录
QSqlRelationalTableModel only populates first 256 records
我有以下使用 PyQt5、sqlite3 和 python3.5.2.
的简单模型
class choicesModel(QDialog):
def __init__(self, parent=None):
super(choicesModel, self).__init__()
query = QSqlQuery()
query.prepare("SELECT COUNT(*) FROM resident_choices")
query.exec_()
query.next()
dbrows = query.value(0)
print("rows in db: ", dbrows)
self.choicesModel = QSqlRelationalTableModel(self)
self.choicesModel.setEditStrategy(QSqlTableModel.OnManualSubmit)
self.choicesModel.setTable("resident_choices")
self.choicesModel.select()
rows = self.choicesModel.rowCount()
print("rows returned by model.select(): ", rows)
执行模型会产生以下输出:
rows in db: 831
rows after model.select(): 256
最初的 select 似乎只填充了前 256 条记录。这是 sqlite3 问题吗?如果是,我该如何填充所有记录(数据库总共只有大约 850 条记录)。如果不是,我如何强制加载所有记录?
结果是,在我更改代理筛选条件之前,使用代理模型和代理视图最初不会显示所有记录——也就是说,我必须触发其余记录的加载。
QSqlQueryModel
class中的#define QSQL_PREFETCH 255
条记录数hard-coded。要覆盖它,您必须自己显式获取所有行:
while self.choicesModel.canFetchMore():
self.choicesModel.fetchMore()
每次更新模型时,您可能需要 运行 编写这样的代码,因此最好创建自己的 sub-class 并重新实现 fetchMore。
我有以下使用 PyQt5、sqlite3 和 python3.5.2.
的简单模型class choicesModel(QDialog):
def __init__(self, parent=None):
super(choicesModel, self).__init__()
query = QSqlQuery()
query.prepare("SELECT COUNT(*) FROM resident_choices")
query.exec_()
query.next()
dbrows = query.value(0)
print("rows in db: ", dbrows)
self.choicesModel = QSqlRelationalTableModel(self)
self.choicesModel.setEditStrategy(QSqlTableModel.OnManualSubmit)
self.choicesModel.setTable("resident_choices")
self.choicesModel.select()
rows = self.choicesModel.rowCount()
print("rows returned by model.select(): ", rows)
执行模型会产生以下输出:
rows in db: 831
rows after model.select(): 256
最初的 select 似乎只填充了前 256 条记录。这是 sqlite3 问题吗?如果是,我该如何填充所有记录(数据库总共只有大约 850 条记录)。如果不是,我如何强制加载所有记录?
结果是,在我更改代理筛选条件之前,使用代理模型和代理视图最初不会显示所有记录——也就是说,我必须触发其余记录的加载。
QSqlQueryModel
class中的#define QSQL_PREFETCH 255
条记录数hard-coded。要覆盖它,您必须自己显式获取所有行:
while self.choicesModel.canFetchMore():
self.choicesModel.fetchMore()
每次更新模型时,您可能需要 运行 编写这样的代码,因此最好创建自己的 sub-class 并重新实现 fetchMore。