SQLite数据库用来处理锁定情况的两个函数

SQLite数据库在使用的过程中经常发生的数据库异常便是数据库被锁定了(SQLITE_BUSY或者SQLITE_LOCKED)。

SQLite对于并发的处理机制是允许同一个进程的多个线程同时读取一个数据库,但是任何时刻只允许一个线程/进程写入数据库。

所以必须要对数据库的读写来进行控制。

SQLite数据库本身用来处理锁定情况的两个函数:

int sqlite3_busy_handler(sqlite3*, int(*)(void*,int), void*);

int sqlite3_busy_timeout(sqlite3*, int ms);

使用这两个函数可以设定当发生数据库锁定的时候,调用什么函数来处理,以及设定锁定时的等待时间。

当然通常情况下我们还可以用另外一种方法来解决这类问题,那便是设置互斥量。一般情况下我们可以使用互斥量,临界区等来实现。在这里我使用了互斥量,主要是因为我需要在多个不同的进程中并发的访问同一个数据库。用于锁定和解锁的函数如下:

void Lock()

{

if((hCounter = OpenMutex(MUTEX_ALL_access,FALSE,"kangxiaofang")) == NULL)

{

//如果没有其他进程创建这个互斥量,则重新创建

hCounter = CreateMutex(NULL,FALSE,"kangxiaofang");

WaitForSingleObject(hCounter,INFINITE);

}

else

{

WaitForSingleObject(hCounter,INFINITE);

}

}

void UnLock()

{

//释放使用权

ReleaseMutex(hCounter);

//关闭句柄

CloseHandle(hCounter);

}

当然我们也可以把等待时间设定为60秒,以免出现死等的现象。具体使用时可以按如下调用:

//锁定数据库

Lock();

rc = sqlite3_exec(db, "BEGIN;", 0, 0, &zErrMsg);

rc = sqlite3_exec(db, exec, 0, 0, &zErrMsg);

rc = sqlite3_exec(db, "COMMIT;", 0, 0, &zErrMsg);

//数据库解锁

UnLock();

总结:

经过测试后,你会发现这种方法所需的消耗要小于循环打开数据库的操作。


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值