首页| 论坛| 消息

标题:Qt编写气体安全管理系统9-数据查询
作者:liudianwu
日期:2019-11-17 09:28
内容:

一、前言
数据查询模块在整个系统中难度最低,由于Qt对数据库操作的封装堪称完美,所以各种查询都是手到擒来,不费吹灰之力。Qt中内置了sqlite数据库,你可以在数据库插件目录sqldrivers发现qsqlite.dll文件比较大,大概800KB左右,而qsqlmysql.dll才70KB,按道理mysql肯定比sqlite要大才对,后面查阅资料发现越来Qt源码中已经包含了sqlite的源码,编译的时候直接内置进去了。这样就大大方便用户使用sqlite数据库了,不像mysql等其他数据库还需要带上对应数据库的动态库文件。其实安卓系统中也大量使用sqlite数据库,足以见得sqlite数据库是有多么的方便。Qt中的数据库通信都在qtsql模块中,主要常用的就是qsqlquery和qsqltablemodel这两个类了,一个用来执行sql语句,别看qsqlquery字面上的意思是查询,其实还包括了添加、删除、修改(基本术语简称增删改)等,反正他可以执行任意的sql语句,只要数据库支持的话,如果有结果返回,会提供一个结果集返回,可以循环遍历取出结果。数据库处理基本上是四个点叫增删改查,这些都是对应的sql语句,具体sql教程推荐可以看这里[https://www.w3school.com.cn/sql/index.asp](https://www.w3school.com.cn/sql/index.asp)。个人做数据库相关的项目以来,除了基本的增删改查以外,基本上就是要注意三点:第一点索引,第二点数据库事务,第三点数据库翻页。
第一点索引,说到数据库查询,不得不说很重要的东西,那就是索引,很多初学者都反应查询好慢啊,才几十万的数据量,就慢成这样子,一问原来没有加索引的缘故,这个知识点通用于任何开发语言而并不是qt独有,这是数据库相关的知识点,强烈建议在数据库建表的时候,如果是常用的需要查询的表,尤其是用到where条件语句的表,必须加上索引,至于索引的字段,建议使用常用的条件的字段,这样在查询的时候速度飞快,索引就相当于新华字典的部首目录或者音节目录,这样可以快速定位具体位置。
第二点数据库事务,加了索引查询是变快了很多,在这种几十万的数据量下,基本上是瞬间忽略不计,也要看具体的字段的数量和每个字段的字节数长度等,如果是几百个字段,那另当别论,不过一般不建议一个表的字段数量特别多,那样没法管理,太难了。索引是加快了查询速度,也会带来一些负面影响比如数据库文件体积变大,基本上会变大50%,不过现在的存储器那么大,基本上没有太大关系,查询是快了,很多初学者又抱怨这Qt真垃圾,添加几百条数 ..

回复 发表
主题 版块