详解Qt 中如何提高Sqlite读写速度

移动开发
本文介绍的是在Qt 中如何提高Sqlite读写速度,SQLite数据库是支持事务操作的,于是我们就可以通过事务来提高数据库的读写速度。先来看详细内容。

Qt 中如何提高Sqlite读写速度 是本文要介绍的内容,SQLite数据库本质上来讲就是一个磁盘上的文件,所以一切的数据库操作其实都会转化为对文件的操作,而频繁的文件操作将会是一个很好时的过程,会极大地影响数据库存取的速度。例如:向数据库中插入100万条数据,在默认的情况下如果仅仅是执行query.exec("insert into DataBase(......) values(......)");就会打开和关闭文件100万次,所以速度当然会很慢。SQLite数据库是支持事务操作的,于是我们就可以通过事务来提高数据库读写速度。事务的基本原理是:数据库管理系统首先会把要执行的sql语句存储到内存当中,只有当commit()的时候才一次性全部执行所有内存中的数据库。下面是一个简单的QT sqlite数据库事务的例子:

  1. #include <QtCore/QCoreApplication> 
  2. #include <QtSql> 
  3. #include <iostream> 
  4.  
  5. using namespace std;  
  6.  
  7. int main(int argc, char *argv[])  
  8. {  
  9. QCoreApplication a(argc, argv);  
  10. QSqlDatabase    db_sqlite = QSqlDatabase::addDatabase("QSQLITE", "connSQLite");  
  11. db_sqlite.setDatabaseName("SQLiteDB.db3");  
  12. db_sqlite.open();  
  13. QSqlQuery   query("", db_sqlite);  
  14. bool    bsuccess = false;  
  15. QTime    tmpTime;  
  16.  
  17. // 开始启动事务  
  18. db_sqlite.transaction();  
  19. tmpTime.start();  
  20. for(int i = 0; i<100000; i++)  
  21. {  
  22.    bsuccess = query.exec("insert into DataBase(D_1,D_2,D_3,D_4,D_5) values('TT','TT','TT','TT','TT')");  
  23.    if (!bsuccess)  
  24.    {  
  25.     cout<<"Error occur"<<endl;  
  26.     break;  
  27.    }  
  28. }  
  29. // 提交事务,这个时候才是真正打开文件执行SQL语句的时候  
  30. db_sqlite.commit();   
  31. cout<<"10000条数据耗时:"<<tmpTime.elapsed()<<"ms"<<endl;  

其实QT 操作sqlite数据库增加事务的功能就是上面例子中蓝色字体标出的两句话,如果去掉这两句话,程序又会还原为:打开文件——执行query.exec(...)——关闭文件。大家可以试一下,添加这两句即增加事务以后数据插入的速度明显提高很多。

在入库和更新过程中按照数据库事务的思想进行设计:SQLite执行入库、更新操作的方式是,sql语句执行对象句柄调用库函数打开文件、调用函数执行sql语句、关闭文件。这样的执行方式对于数量级别超大的文件的弊端就是每次执行sql语句的时候都要打开文件(假设***数量级的数据,就要打开和关闭文件百万次),对于数据库的入库和更新操作时间主要都浪费到了文件的打开和关闭操作上,所以这里增加事务以解决该问题。

小结:关于详解Qt 中如何提高Sqlite读写速度的内容介绍完了,希望本文对你有所帮助。更多关于数据库的内容请参考编辑推荐。

责任编辑:zhaolei 来源: 互联网
相关推荐

2011-07-04 17:18:23

Qt SQLite 数据库

2011-11-17 15:30:34

JavaNIOIO

2016-09-07 15:02:03

ElasticSear索引速度

2011-08-22 16:26:25

IOS开发Sqlite数据库

2011-07-05 17:54:43

QT Sqlite ARM

2011-07-01 14:06:57

Qt sqlite

2011-07-04 17:26:00

Qt SQLite

2011-05-30 13:28:00

PHP

2011-07-05 10:44:51

Qt Sqlite 静态编译

2009-11-04 13:38:34

.NET缓存

2011-08-30 14:15:34

QTSQLite数据库

2019-09-24 09:25:05

Vue项目加载

2011-05-19 11:33:38

数据库访问速度

2011-07-05 10:22:44

Qt Sqlite

2011-06-14 11:48:38

Webkit QT

2009-10-16 08:48:08

2022-04-27 09:24:22

前端代码速度

2011-07-05 14:46:34

2010-01-06 16:55:33

Web交换机

2011-06-24 09:13:30

QT SDL
点赞
收藏

51CTO技术栈公众号