码迷,mamicode.com
首页 > 数据库 > 详细

sqlite:多线程操作数据库“database is locked”解决方法(二)

时间:2014-10-16 21:10:23      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   使用   ar   strong   sp   

上一篇博客《sqlite:多线程操作数据库“database is locked”解决方法》通过注册延时函数的方法来处理数据库被锁的问题。此方法固然能解决问题,但是在多个线程向数据库写入大量数据的情况下,延时会拖慢进度。

想出方法二:

1. 创建一个链表,链接如下格式的结构体,线程1,线程2,线程3......不直接改写数据库,而是把sql语句插入链表中;

typedef struct {

uint8_t *buf;

uint32_t len;

} sqlItem_t;

2. 创建一个独立的线程,专职从链表中读取sql语句,对数据库进行改写。

这样只有一个线程对数据库进行操作,数据库被锁的问题即可避免了,对数据库的处理效率也大大提高。

3. 使用事务进一步提高sqlite处理性能

思路如下:

执行"begin transaction;"语句
执行多条insert/update/delete/...语句
执行"commit transaction;"语句

 

sqlite:多线程操作数据库“database is locked”解决方法(二)

标签:style   blog   http   color   io   使用   ar   strong   sp   

原文地址:http://www.cnblogs.com/tanghuimin0713/p/4029503.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!