QT的QSqlQuery与QSqlQueryModel RowCount只能读到256问题的解决

简介:

在使用QTQSqlQueryModel操作SQLite数据库的时候,通过model->rowCount();只能返回最多256。这个问题需要通过在操作结果前先通过fetchmore()来获取所有的结果,然后获得具体的行数。

         QTQSqlQueryQSqlQueryModel每次最多只能缓存查询结果的256条。如果查询语句操作的结果超过256条了,也只能返回256。这样就必然会导致在后续操作中的错误。

     解决方法如下:

1.    while(model->canFetchMore())  

2.      {  

3.          model->fetchMore();  

4.      }  

5.      

6.     for(int i = 0; i < model->rowCount(); i++)  

7.      

8.     {  

9.      

10.      qDebug()<<model->data(model->index(i,0)).toString();  

11.    

12.   }  




本文转自313119992 51CTO博客,原文链接:http://blog.51cto.com/qiaopeng688/1715890

相关文章
|
7月前
|
数据库 数据安全/隐私保护
使用 OPEN CURSOR 和 FETCH NEXT CURSOR 对 SAP 数据库表进行分块读写试读版
使用 OPEN CURSOR 和 FETCH NEXT CURSOR 对 SAP 数据库表进行分块读写试读版
37 2
|
存储 easyexcel Java
实战--excel分别实现按行读和按列读(其实是按单元格读)
实战--excel分别实现按行读和按列读(其实是按单元格读)
229 0
实战--excel分别实现按行读和按列读(其实是按单元格读)
使用SELECT和OPEN CURSOR读取product数据的一些讨论
使用SELECT和OPEN CURSOR读取product数据的一些讨论
178 0
使用SELECT和OPEN CURSOR读取product数据的一些讨论
|
存储 分布式数据库
使用SELECT 和OPEN CURSOR 读取big table的性能比较
使用SELECT 和OPEN CURSOR 读取big table的性能比较
125 0
使用SELECT 和OPEN CURSOR 读取big table的性能比较