安庆大理运城常德铜陵江西
投稿投诉
江西南阳
嘉兴昆明
铜陵滨州
广东西昌
常德梅州
兰州阳江
运城金华
广西萍乡
大理重庆
诸暨泉州
安庆南充
武汉辽宁

Qt编写物联网管理平台47通用数据库设置

2月18日 火云谷投稿
  一、前言
  为了做这个通用的数据库组件,专门安装了虚拟机来安装各种版本的不同类型的数据库做测试,包括编译对应的数据库插件,我一直坚信的是一切从实际出发有实际采用发言权,包括不同Qt版本编译mysql、oracle数据库插件,以及不同数据库在查询数据、分页显示数据、清空数据、批量插入数据、批量删除数据等操作,经历过至少半个月的疯狂实战,光mysql就安装了5。7和8。0版本,postgresql安装了9。0、10。0、13。0三个版本,oracle安装了11。0,国产数据库安装了kingbaseV8,反复将物联网管理平台、视频监控系统、可视化大屏电子看板系统,在各种数据库下进行测试,优化了大大小小上百个细节,而且同时支持直连数据库和ODBC数据源方式连接数据库两种形式,比如通过oci库搭配qoci插件连接oracle数据库、通过odbc数据源搭配qodbc插件连接oracle数据库,才形成现在的版本。
  通用的数据库组件基本功能:探测数据库连接是否正常,一般是在不指定数据库名称的前提下探测,因为此时数据库并不存在,需要连接后再去新建。执行sql脚本初始化数据库,包括新建数据库、新建数据库表、初始化记录等。通用数据库连接和管理类,负责数据库的打开、关闭、执行sql语句、批量执行、自动重连、实时检测连接状态等。通用数据库记录清理类,负责清理指定数据库表的记录。通用数据库记录翻页类,不同数据库类型对应不同的查询翻页显示记录语句。绑定数据库表到数据模型QSqlTableModel。获取查询记录数语句,不同数据库类型不同sql语句。查询数据库所有表名、所有字段名,不同数据库类型不同sql语句。通用日期范围sql语句。二、功能特点2。1软件模块设备监控模块,包括数据监控(表格形式展示)、设备面板(面板形式展示)、地图监控(地图形式展示)、曲线监控(曲线形式展示)。数据查询模块,包括报警记录、运行记录、操作记录。系统设置模块,包括基本设置、端口管理、控制器管理、探测器管理、报警联动、类型设置等。其他设置模块,包括用户管理、地图管理、位置调整、组态设计、设备调试等。2。2基础功能设备数据采集,支持串口、网络,串口可设置串口号、波特率,网络可设置IP地址、通讯端口。每个端口支持采集周期时间,默认1秒钟一个设备。支持设置通讯超时次数,默认3次。支持最大重连时间,用于重新读取离线的设备。控制器信息,能够添加控制器名称,选择控制器地址、控制器型号,设置该控制器下面的探测器数量。探测器信息,能够添加位号、探测器型号、气体种类、气体符号、高报值、低报值、缓冲值、清零值、是否启用、报警声音、背景地图、存储周期、数值换算小数点位数、报警延时时间、报警的类型(HH,LL,HL)等。类型管理可配置控制器型号、探测器型号、气体种类、气体符号等。地图支持导入和删除,所有的探测器在地图上的位置可自由拖动保存。端口信息、控制器信息、探测器信息、类型信息、用户信息等,都支持导入、导出、导出到excel、打印。运行记录、报警记录、操作记录,都支持多条件组合查询,比如时间段、控制器、探测器等,所有记录支持导出到excelpdf和打印。运行记录、报警记录、操作记录都可删除指定时间范围内的数据。系统设置可选择对应表最大保存记录数,自动清理早期数据,留出足够的空间存储重要的数据。报警短信转发,支持多个接收手机号码,可设定发送间隔,比如即时发送或者6个小时发送一次所有的报警信息,短信内容过长,自动拆分多条短信。报警邮件转发,支持多个接收邮箱,可设定发送间隔,比如即时发送或者6个小时发送一次所有的报警信息,支持附件发送。设置软件的中文标题、英文标题、logo路径、版权所有等。开关设置开机运行、报警声音、自动登录、记住密码等。报警声音可设置播放次数,界面风格样式提供18套皮肤文件选择。用户管理,包括用户权限配置,不同用户可以有不同模块的权限。用户登录和用户退出,可以记住密码和自动登录,超过三次报错提示并关闭程序。四种监控模式,设备面板监控、地图监控、表格数据监控、曲线数据监控,可自由切换,四种模式下都实时展示采集到的数据,报警闪烁等。报警继电器联动,一个位号可以跨串口联动多个模块和继电器号,支持多对多。2。3特色功能通信协议支持modbuscom、modbustcprtu,后期拓展mqtt等协议。数据源除了真实的硬件设备采集,还可选数据库采集,这样用户可以安排其他程序员比如java程序员将前端采集好的数据放到数据库,本系统直接从数据库采集即可。数据库采集模式可以作为通用的系统使用,更适合多人多系统协作。智能跳过超时的设备,加快对在线设备的采集速度,当设备数量很多的时候尤其有用。对智能跳过的超时的设备,在设定的重连时间自动采集一次,以便探测设备是否又重新上线。每个探测器可控是否启用,不启用则不会采集,也不会在界面显示,相当于运行阶段临时关闭。探测器可设置缓冲值和报警延时时间,在该值附近波动产生的报警,不计入报警,只有持续处于报警值且超过报警延时时间才算真正报警,这样可以规避很多波动导致的误报。探测器可设置存储周期,按照设定的时间来存储一条运行记录,可以按照重要程度对重要性高的设定存储周期短一些,不重要的设定大一些,这样可以节省不少的存储空间,也保证了重要的数据及时存储。探测器可设置清零值,在一些高精度高灵敏的设备可能出厂的时候默认值未必是0,需要设定清零值来表示初始值。探测器可设置小数点,用于计算后的真实数据控制小数点点位显示,相当于除以10、除以100、除以1000,这样大部分的探测器数据直接通过小数点位设置控制真实换算后的值,极个别的需要特殊转换的可以在通信协议中约定。探测器报警的类型支持多种,有些设备是高于某个值高报,低于某个值低报,而有些设备是在最小值最大值范围内是高报,低于最小值低报,高于最大值正常。这样可以分情况处理,涵盖各种报警类型。原创数据导入、导出、打印机制,跨平台不依赖任何组件,瞬间导出数据。导出到excel的记录支持所有excel、wps等表格文件版本,不依赖excel等软件。高报颜色、低报颜色、正常颜色、默认值颜色等,都可以自由设置。支持云端数据同步,将本地采集到的数据实时同步到云端。支持网络转发和网络接收,网络接收开启后,软件从udp接收数据进行解析。网络转发支持多个目标IP,这样就实现了本地采集的软件,自由将数据转到客户端,随时查看采集到的数据。自动记住用户最后停留的界面以及其他配置信息,重启后自动应用。报警自动切换到对应的地图,探测器按钮闪烁,表格数据对应颜色显示。双击探测器图标,弹出对应探测器详细信息,可以根据需要定制回控操作。数据库支持多种,包括sqlite、mysql、sqlserver、postgresql、oracle、人大金仓等。本地设备采集到的数据实时上传到云端,以便手机APP或者web等其他方式提取。自带设备模拟工具,支持不同型号的多个设备数据模拟,同时还带数据库数据模拟,以便在没有设备的时候测试数据。标准modbus协议,各种控制器类型、探测器类型、种类、符号等全部自定义,非常灵活和强大,通信协议示例数据非常完整,通用各种modbus协议系统,适用于各种应用场景接入。同时集成了串口通信、网络通信、数据库通信、数据导入导出打印、通信协议解析、界面UI、全局换肤等众多组件和知识点,非常适合新手入门和进阶。支持xp、win7、win10、、win11、linux、mac、各种国产系统(UOS、中标麒麟、银河麒麟等)、嵌入式linux等系统。注释完整,项目结构清晰,超级详细完整的使用开发手册,精确到每个代码文件的功能说明,不断持续迭代版本。三、体验地址国内站点:https:gitee。comfeiyangqingyun国际站点:https:github。comfeiyangqingyun个人主页:https:blog。csdn。netfeiyangqingyun知乎主页:https:www。zhihu。compeoplefeiyangqingyun产品主页:https:blog。csdn。netfeiyangqingyunarticledetails97565652在线文档:https:feiyangqingyun。gitee。ioqwidgetdemoiotsystem体验地址:https:pan。baidu。coms1ZxGoyUKe286LPMPxOrO2A提取码:o05q文件名:biniotsystem。zip。文章导航:https:qtchina。blog。csdn。netarticledetails121330922四、效果图
  五、相关代码voidfrmConfigDb::onbtnConnectclicked(){{初始化数据库连接信息结构体数据DbInfodbIinitDbInfo(dbInfo,connName);QStringdbTypeAppConfig::LocalDbType。toUpper();if(dbTypeSQLITE){dbInfo。dbNameDbHelper::getDbDefaultFile(connFlag);if(QFile(dbInfo。dbName)。size()4){QUIHelper::showMessageBoxError(数据库文件不存在!,5);}}QSqlDif(DbHelper::initDatabase(true,dbType,database,dbInfo)){if(database。open()){database。close();QUIHelper::showMessageBoxInfo(打开数据库成功!,3);}else{QStringerrordatabase。lastError()。text();QUIHelper::showMessageBoxError(打开数据库失败!error,3);}}else{QStringerrordatabase。lastError()。text();QUIHelper::showMessageBoxError(连接数据库失败!error,3);}}QSqlDatabase::removeDatabase(connName);}voidfrmConfigDb::onbtnInitclicked(){if(QUIHelper::showMessageBoxQuestion(确定要初始化数据库吗?会全部清空数据并且不可还原!)!QMessageBox::Yes){}QStringsqlNameQString(1db2。sql)。arg(QUIHelper::appPath())。arg(connFlag);QFilefile(sqlName);if(!file。open(QIODevice::ReadOnlyQIODevice::Text)){QUIHelper::showMessageBoxError(数据库脚本文件打开失败!,3);}QElapsedTtime。start();{初始化数据库连接信息结构体数据DbInfodbIinitDbInfo(dbInfo,connName);QStringdbTypeAppConfig::LocalDbType。toUpper();if(dbTypeSQLITE){dbInfo。dbNameDbHelper::getDbDefaultFile(connFlag);如果文件存在则先删除原来的数据库文件,貌似win上不行QFilefile(dbInfo。dbName);if(file。exists()){boolokfile。remove();if(!ok){qDebug()TIMEMSremoveerrordbInfo。dbN}清空所有表QStringListtablesQSqlDatabase::database()。tables();foreach(QStringtable,tables){DbHelper::clearTable(table,dbType);qDebug()TIMEMSclearT}关闭默认数据库连接QSqlDatabase::database()。close();}}初始化数据库连接并打开数据库QSqlDif(!DbHelper::initDatabase(true,dbType,database,dbInfo)){QStringerrordatabase。lastError()。text();QUIHelper::showMessageBoxError(连接数据库失败!error,3);}if(!database。open()){QStringerrordatabase。lastError()。text();QUIHelper::showMessageBoxError(打开数据库失败!error,3);}QSqlQueryquery(QSqlDatabase::database(connName));第一步:删除原有数据库QStringsqlQString(DROPDATABASE1;)。arg(dbInfo。dbName);qDebug()TIMEMSsql:sqlresult:query。exec(sql);第二步:新建数据库sqlQString(CREATEDATABASE1;)。arg(dbInfo。dbName);qDebug()TIMEMSsql:sqlresult:query。exec(sql);第三步:切换到新建的数据库库并执行建表语句database。close();if(!DbHelper::initDatabase(false,dbType,database,dbInfo)){QStringerrordatabase。lastError()。text();QUIHelper::showMessageBoxError(连接数据库失败!error,3);}if(!database。open()){QStringerrordatabase。lastError()。text();QUIHelper::showMessageBoxError(打开数据库失败!error,3);}将执行出错的sql语句输出到文件方便查看QStringfileName2QString(1dberror。sql)。arg(QUIHelper::appPath());QFilefile2(fileName2);QSqlQueryquery2(QSqlDatabase::database(connName));sqlBEGIN;;qDebug()TIMEMSsql:sqlresult:query2。exec(sql);while(!file。atEnd()){sqlQString::fromUtf8(file。readLine());sql。replace(,);有些数据库不支持的语句跳过去if(DbHelper::existNoSupportSql(sql)){}重新纠正sql语句DbHelper::checkSql(dbType,sql);if(!query2。exec(sql)){打印及输出错误信息QStringerrorquery2。lastError()。text();qDebug()TIMEMSsql:没打开则先打开if(!file2。isOpen()){file2。open(QFile::WriteOnlyQFile::Append);}QStringmsgQString(时间〔1〕语句:2错误:3)。arg(DATETIME)。arg(sql)。arg(error);file2。write(msg。toUtf8());}}sqlCOMMIT;;qDebug()TIMEMSsql:sqlresult:query2。exec(sql);database。close();sqlite数据库的话再执行下压缩减少体积if(dbTypeSQLITE){DbHelper::execSql(VACUUM;);}}QSqlDatabase::removeDatabase(connName);doublemstime。elapsed();QStringinfoQString(数据库脚本执行成功,总共用时1秒!记得重新启动程序!)。arg(QString::number(ms1000,f,1));QUIHelper::showMessageBoxInfo(info,3);}
投诉 评论

北马开跑,冠军是他们11月6日,参赛选手在比赛中出发。新华社记者张晨霖摄2022北京马拉松6日举行获得男、女冠军的中国选手阿奴拜克库弯和夏雨雨均刷新个人最好成绩11月……人过五十去结善缘,是后半生最上等的风水禅门有一句诗偈:寻常一样窗前月,才有梅花便不同。意思是说,在一冬天的夜晚,来了志同道合的朋友,他们在月光下,啜茗清谈,主客相谈甚欢,这气氛可就与平常大不一样的了。人……一代传奇落幕!他是中国马拉松第一人11月7日从合肥市马拉松协会主席魏普龙处获悉张亮友老先生于11月7日上午10点07分在江苏仪征的家中去世享年95岁或许还有很多网友不了……周看点移动物联网实现物超人鸿海联电冲刺第三代半导体一周热点点评工信部:我国移动物联网连接数达16。98亿近日,工业和信息化部公布了2022年18月份通信业经济运行情况。截至8月末,三家基础电信企业发展蜂窝物联网终端……三消息拜仁挖角新目标国际米兰锁定三强人曼联助攻巴萨引两名将第一个消息:拜仁寻神锋有新目标!重演挖角拿手好戏,法国新星最快赛季后加盟由于巴萨一直忙于处理财政平衡的事宜,所以已经确定加盟的米兰中场悍将凯西和切尔西顶级中卫克里斯滕森仍……展望下半年关于风电产业链投资展望及深度解析(附龙头股)保本、守心、求突破,每天思考一点,且行且珍惜〔玫瑰〕近些年随着经济高质量发展的推进,新兴行业在A股的权重大幅增加,且单个新兴产业链可能横跨多个一级或二级行业,其上中下游产……金铲铲之战时空裂痕吃鸡整容解析上次我讲过,金铲铲之战,吃鸡靠命,前4靠技术;今天我就拿一个案例给大家解析一下我的上分攻略。7羁绊吃鸡整容上次跟大家分享过,我的打法主要以:换形师法师的核心阵……新神榜杨戬上映,大眼橙X20陪你宅家再刷国风动漫封神榜又一部动画电影上映啦,这次的主角是杨戬,片名:《新神榜:杨戬》。上映几天,获得的评价很多,不过相信咱们国风动漫的实力,能在中国风古风质感上做到更加独特绚丽,加上神话设定元……乘机指南(孕妇篇)怀孕不足32周的孕妇乘机,除医生诊断不适宜乘机者外,按一般旅客运输。怀孕满32周(含)未满36周的孕妇,且预产期确定并超过4周,并已知不是多胎或没有分娩并发症的旅客如需乘……Qt编写物联网管理平台47通用数据库设置一、前言为了做这个通用的数据库组件,专门安装了虚拟机来安装各种版本的不同类型的数据库做测试,包括编译对应的数据库插件,我一直坚信的是一切从实际出发有实际采用发言权,包括不……国际足联裁定厄瓜多尔争议国脚身份世界杯照常踢北京时间6月10日晚,国际足联在官网发布公告,宣布国际足联纪律委员会确认,认定厄瓜多尔国脚拜伦卡斯蒂略的参赛资格无误。这也意味着,此前被指控使用外籍国脚的厄瓜多尔队确定可以参加……腌糖蒜,只放糖和醋不正宗,牢牢记住3个诀窍,酸甜爽脆久放不坏腌糖蒜,只放糖和醋不正宗,牢牢记住3个诀窍,酸甜爽脆久放不坏最近几天,我们家已经吃上了五月底腌的糖蒜,虽然还没有彻底腌透,但是也可以吃了。是不是感觉我们家,腌制的时间太长……
男人的这些模样,只会展现给他最爱的女人品牌realme双11降价信息汇总你有换机打算吗?电影少林寺走红之前,千年古刹少林寺竟如此破败不堪绿通科技上下游大量重叠前员工变身经销商交易价格难言公允到了45岁后,无论是否吸烟喝酒,都建议你饮用这3种茶保护身体42!穆帅运气好到家,竞争对手全遭阻击,罗马掌握主动权生完宝宝后,你的胎盘是怎么处理的?宝妈我被家人骗着吃了奥运冠军入籍中国,无缘北京冬奥会人生若是拥有一个年轻良好的心态,绝对胜过世间的一切灵丹妙药夏天空调开多少度最合适?6招教你远离空调病这3招,快速拿捏笨蛋美人的美感10人大名单解读,榜眼探花8位首轮秀,火箭队赢在未来马伊琍代言出事,盘点这些年不负责任的明星代言蜂蜜柚子茶能做面膜吗怎么做面膜有什么功效很多人都说秋葵能补肾壮阳秋葵真的有这么神奇吗我心目中的英雄玉米钓草鱼用多大的钩子?王子飞鸟山看红叶饮扇屋精选喜庆婚礼的结婚对联怎样有效防止宝宝磨牙让你事半功倍的效率工作法:GTD、敏捷方法、番茄工作法。。。我的老师作文800字如何理解房地产税小孩子骄傲自大怎么办骄傲自满的孩子如何教育

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找七猫云易事利