测试:
这里有一个sqlite数据库
data:image/s3,"s3://crabby-images/820c6/820c68afcf438cfbe9803be9ecf509dee04d4dd3" alt=""
存储了10万多条数据,col1是1,col2是2.
data:image/s3,"s3://crabby-images/8939a/8939a9db0faa9a76dc6a566ecc50bf28361d78d2" alt=""
使用QSqlQueryModel和QTableView来显示这些数据,也非常非常流畅。
cpp
QString aFile = QString::fromLocal8Bit("E:/桌面/3.db");
if (aFile.isEmpty())
return;
//打开数据库
DB = QSqlDatabase::addDatabase("QSQLITE");
DB.setDatabaseName(aFile); //设置数据库名称
if (!DB.open()) //打开数据库
{
QMessageBox::warning(this, "错误", "打开数据库失败",
QMessageBox::Ok, QMessageBox::NoButton);
return;
}
qryModel = new QSqlQueryModel(this);
qryModel->setQuery("select rowid,col1,col2 from test;");
if (qryModel->lastError().isValid())
{
QMessageBox::critical(this, "错误", "数据表查询错误,错误信息\n" + qryModel->lastError().text(),
QMessageBox::Ok, QMessageBox::NoButton);
return;
}
tableView = new QTableView;
tableView->setModel(qryModel);
this->setCentralWidget(tableView);
data:image/s3,"s3://crabby-images/6df2b/6df2b8ef810442a4d498469583e7ac7f83dedcc5" alt=""
可以看到数据是动态加载的。