效果图:
上述是读取数据库的进度条(因为查询的数据量较大,所以需要进度条给客户展示)。
代码,进度条所需部分如下,其他地方根据需求自行填充
首先需要在头文件中设置添加私有成员变量(包含头文件#include <QProgressDialog>)
.h
private:
QProgressDialog* progressDialog;
.cpp
//查询数据库...
//创建进度对话框(),totalCount是所查询数据库的行数
QProgressDialog progressDialog(QStringLiteral("查询中..."), "Cancel", 0, totalCount, this);
progressDialog.setWindowModality(Qt::WindowModal);
progressDialog.setMinimumDuration(0); // 立即显示进度对话框
// 更新进度
progressDialog.setValue(row + 1);
// 处理界面事件,确保界面不会冻结
QCoreApplication::processEvents();
// 如果用户点击了取消按钮,则停止查询
if (progressDialog.wasCanceled()) {
qDebug() << "Query cancelled by user.";
return;
}
progressDialog.close();
totalCount : 总行数有很多种方法,如.size(),rowcount,.next什么的,但在我的程序中都不起效。
最后使用的方法是
int totalCount = 0;//总行数
if (query.last())
{
totalCount = query.at();
}
query.first();//重新定位指针到结果集首位(因为我后面要把数据库数据放到一个list里)