Qt数据库应用之实现通用数据生成器
作者:feiyangqingyun 发布时间:2024-01-16 00:37:49
一、前言
有两种应用场景需要用到数据生成器,一种是需要测试数据库性能,比如在100万条和1000万条记录的时候对比查询或更新语句执行耗时,一种是随机模拟生成一堆数据,用来测试程序的性能,看下程序中到了百万千万级别的数据量的时候,程序的代码执行是否受影响,影响有大等。很多人觉得sqlite数据库性能超过几十万就不行,于是亲自用这个数据发生器随机模拟生成了一亿条记录,测试下来发现性能有损失,但是不像传说中的垃圾,起码还是完全可用的,只要注意索引要建好,文件体积比较大就是,文件体积膨胀到了1.2GB,估计性能损耗很大程度上在磁盘读写。
通过对各种数据库(sqlite、postgres、mysql、sqlserver等)不同数据量阶段(1万条、100万条、1000万条等)做不同的sql语句处理(查询、插入、删除、更新),Qt内置了sqlite数据库,所以对sqlite的支持是最快最友好的,其次是postgresql数据库、然后是mysql,支持最差的性能最低的是ODBC模式连接的数据库,比如sqlserver数据库必须用odbc的形式连接,由于odbc是一个中间层,理论上性能也是肯定没有直接连接处理快,不过纵观各种用Qt写的项目的场景,很少是需要千万级别亿级别的数据量的,真的到了这个程度可以考虑分库分表来解决。
关于Qt数据库相关开发的一些经验总结
二、功能特点
同时支持多种数据库比如odbc、sqlite、mysql、postgresql、sqlserver、oracle、人大金仓等。
一个数据库类即可管理本地数据库通信,也支持远程数据库通信等。
数据库线程支持执行各种sql语句,包括单条和批量。
组件中的所有类打印信息、错误信息、执行结果都信号发出去。
集成数据库通用翻页类(负责具体处理逻辑),搭配分页导航控件(负责外观),形成超级牛逼的翻页控件。
集成数据库自动清理类,设定最大记录数后台自动清理早期数据。
集成自定义委托类,支持复选框、文本框、下拉框、日期框、微调框、进度条等。
同时支持Qt4-Qt6,亲测Qt4.6到Qt6.3任意版本,任意系统和编译器。
本组件无故障 360天7乘24小时 运行在至少上万个现场,商业级别品质保证。
每个类都对应完整详细的使用示例,注释详细,非常适合阅读学习。
可以作为独立的程序运行,比如自动清理早期数据,同步数据到云端。
全部线程处理,不卡界面,自动重连数据库。
普通测试情况,sqlite数据库,数据库发生器每秒钟插入1000条记录约0.003秒钟,同时自动清理数据类每秒钟删除1000条记录约0.13秒,不同线程互不干扰。
三、体验地址
体验地址:https://pan.baidu.com/s/15ZKAlptW-rDcNq8zlzdYLg 提取码:uyes 文件名:bin_dbtool.zip
国内站点:https://gitee.com/feiyangqingyun
国际站点:https://github.com/feiyangqingyun
四、效果图
五、相关代码
void frmDbCreat::on_btnOpen_clicked()
{
if (ui->btnOpen->text() == "打开数据库") {
DbInfo dbInfo;
dbInfo.connName = this->objectName();
dbInfo.dbName = AppConfig::DbName2;
dbInfo.hostName = AppConfig::HostName2;
dbInfo.hostPort = AppConfig::HostPort2;
dbInfo.userName = AppConfig::UserName2;
dbInfo.userPwd = AppConfig::UserPwd2;
QString dbType = AppConfig::DbType2.toUpper();
if (dbType == "SQLITE") {
dbInfo.dbName = DbHelper::getDbDefaultFile();
}
dbConn->setConnInfo(DbHelper::getDbType(dbType), dbInfo);
if (dbConn->openDb()) {
dbConn->start();
ui->btnOpen->setText("关闭数据库");
} else {
QString error = dbConn->getDatabase().lastError().text();
QUIHelper::showMessageBoxError("打开数据库失败!\n" + error, 3);
}
} else {
dbConn->stop();
dbConn->closeDb();
ui->btnOpen->setText("打开数据库");
on_btnClear_clicked();
}
QTimer::singleShot(100, this, SLOT(getMaxID()));
QTimer::singleShot(1000, this, SLOT(on_btnStart_clicked()));
}
void frmDbCreat::on_btnCopy_clicked()
{
//将数据库设置参数一键粘贴过来
ui->cboxDbType->setCurrentIndex(ui->cboxDbType->findText(AppConfig::LocalDbType));
ui->txtDbName->setText(AppConfig::LocalDbName);
ui->txtHostName->setText(AppConfig::LocalHostName);
ui->txtHostPort->setText(QString::number(AppConfig::LocalHostPort));
ui->txtUserName->setText(AppConfig::LocalUserName);
ui->txtUserPwd->setText(AppConfig::LocalUserPwd);
}
void frmDbCreat::getMaxID()
{
if (!dbConn->getOk()) {
return;
}
//根据插入sql语句取出对应的表名和自增字段
QString sqlColumn = AppConfig::SqlColumn2;
QString sqlValue = AppConfig::SqlValue2;
if (sqlValue.contains("AUTO_INCREMENT")) {
sqlColumn.replace("insert into ", "");
sqlValue.replace("values", "");
QString tableName = sqlColumn.split("(").first();
sqlColumn.replace(tableName, "");
sqlColumn.replace("(", "");
sqlColumn.replace(")", "");
sqlValue.replace("(", "");
sqlValue.replace(")", "");
QStringList listColumn = sqlColumn.split(",");
QStringList listValue = sqlValue.split(",");
int index = listValue.indexOf("'AUTO_INCREMENT'");
QString columnName = listColumn.at(index);
//取出最大记录数
maxID = DbHelper::getMaxID(tableName, columnName, dbConn->getDatabase());
}
}
void frmDbCreat::on_btnDo_clicked()
{
if (!dbConn->getOk()) {
return;
}
QString sql = AppConfig::SqlColumn2 + " " + AppConfig::SqlValue2;
//qDebug() << TIMEMS << sql;
QStringList sqls;
for (int i = 0; i < AppConfig::Count2; ++i) {
QString temp = sql;
//替换自增ID
maxID++;
temp.replace("AUTO_INCREMENT", QString::number(maxID));
//替换时间
temp.replace("DATETIME", DATETIME);
sqls << temp;
}
dbConn->append(sqls);
}
void frmDbCreat::on_btnCount_clicked()
{
dbConn->selectCount("LogInfo", "LogID", "where 1=1");
}
void frmDbCreat::on_btnStart_clicked()
{
if (ui->btnStart->text() == "启动服务") {
on_btnDo_clicked();
timer->start();
ui->btnStart->setText("停止服务");
} else {
timer->stop();
ui->btnStart->setText("启动服务");
}
}
来源:https://blog.csdn.net/feiyangqingyun/article/details/123001131


猜你喜欢
- 开发工具Python版本:3.6.4相关模块:pygame模块;以及一些python自带的模块。环境搭建安装Python并添加到环境变量,p
- 全局作用域下this;当在全局作用域中使用 this,它指向全局对象。这里详细介绍下全局对象:全局对象(Global object) 是在进
- 三种解决方法: 1、改表法。可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mys
- 网络技术,无论是php还是java ,无论是pc时代,还是移动时代,无论是黑客技术,还是程序新人,it技术,无疑是当前最火的行业,无论是个人
- 300来行python代码实现简易版学生成绩管理系统,供大家参考,具体内容如下使用链表来实现class Node(object): def
- 1.VsCode官方插件地址:https://marketplace.visualstudio.com/vscodehttp://code.
- Pycharm是一款很好用的python开发工具,开发Python爬虫和Python web方面都很不错这里我为大家提供了两种pycharm
- 在tensorflow中,默认指定占用所有的GPU,如需指定占用的GPU,可以在命令行中:export CUDA_VISIBLE_DEVIC
- 一、什么是上下文管理器我们在处理文件的时候经常看到下面这样的代码,它即是上下文管理器:with open('test.txt'
- 在Google Chrome浏览器出来之前,我一直使用FireFox,因为FireFox的插件非常丰富,更因为FireFox有强大的Fire
- 项目背景 在之前的一个项目中用Python的Flask写了一个提供公共基础服务的Rest应用,上面大佬的意思是需要将这一部分封装成容器化服
- 一、简介:1、cron包cron包:"github.com/robfig/cron/v3"文档:cron package
- node有一个模块叫n(这名字可够短的。。。),是专门用来管理node.js的版本的。首先安装n模块:npm install -g n第二步
- 一、Pytorch创建张量的4种方法Pytorch创建张量的4种方法主要有:torch.Tensor()、torch.tensor()、to
- SQL Server 提供系统数据类型集,定义了可与 SQL Server 一起使用的所有数据类型。下面列出系统提供的数据类型集。 可以定义
- 这篇文章主要介绍了简单了解python装饰器原理及使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要
- 目录通过python的tkinter实现简单的注册登录代码截图登录页面注册页面个人主页修改个人信息失败修改个人信息成功重新登录twb总结通过
- 本文实例讲述了python单向循环链表原理与实现方法。分享给大家供大家参考,具体如下:单向循环链表单链表的一个变形是单向循环链表,链表中最后
- 1、其中再语义分割比较常用的上采样:其实现方法为:def upconv2x2(in_channels, out_channels, mode
- 前言golang的指针receiver和非指针receiver的区别?最近在看网站有同学提问golang中方法的receiver为指针和不为