深入SQLite多线程的使用总结详解
串行:sqlite是线程安全的。启用所有的锁,包括bCoreMutex和bFullMutex。因为数据库连接和preparedstatement都已加锁,所以多线程使用这些对象时没法并发,也就变成串行了。当SQLite编译时加了SQLITE_THREADSAFE=1参数时默认启用。若SQLITE_THREADSAFE不为0,可以在初始化SQLite前,调用sqlite3_config(SQLITE_CONFIG_SERIALIZED)启用;或者在创建数据库连接时,设置SQLITE_OPEN_FULLMUTEXflag 。
而这里所说的初始化是指调用
为了达到线程安全,SQLite在编译时必须将SQLITE_THREADSAFE预处理宏置为1。在Windows和Linux上,已编译的好的二进制发行版中都是这样设置的。如果不确定你所使用的库是否是线程安全的,可以调用sqlite3_threadsafe()接口找出。
也就是说线程模式可以在编译时(通过源码编译sqlite库时)、启动时(使用sqlite的应用程序初始化时)或者运行时(创建数据库连接时)来指定。一般而言,运行时指定的模式将覆盖启动时的指定模式,启动时指定的模式将覆盖编译时指定的模式。但是,单线程模式一旦被指定,将无法被覆盖。默认的线程模式是串行模式。
编译时选择线程模式
可以通过定义SQLITE_THREADSAFE宏来指定线程模式。如果没有指定,默认为串行模式。定义宏SQLITE_THREADSAFE=1指定使用串行模式;=0使用单线程模式;=2使用多线程模式。
sqlite3_threadsafe()函数的返回值可以确定编译时指定的线程模式。如果指定了单线程模式,函数返回false。如果指定了串行或者多线程模式,函数返回true。由于sqlite3_threadsafe()函数要早于多线程模式以及启动时和运行时的模式选择,所以它既不能区别多线程模式和串行模式也不能区别启动时和运行时的模式。
最后一句可通过sqlite3_threadsafe函数的实现来理解SQLITE_APIintsqlite3_threadsafe(void){returnSQLITE_THREADSAFE;}如果编译时指定了单线程模式,那么临界互斥逻辑在构造时就被省略,因此也就无法在启动时或运行时指定串行模式或多线程模式。
启动时选择线程模式
假如在编译时没有指定单线程模式,就可以在应用程序初始化时使用sqlite3_config()函数修改线程模式。参数SQLITE_CONFIG_SINGLETHREAD可指定为
单线程模式,SQLITE_CONFIG_MULTITHREAD指定为多线程模式,SQLITE_CONFIG_SERIALIZED指定为串行模式。
运行时选择线程模式
如果没有在编译时和启动时指定为单线程模式,那么每个数据库连接在创建时可单独的被指定为多线程模式或者串行模式,但是不能指定为单线程模式。如果在编译时或启动时指定为单线程模式,就无法在创建连接时指定多线程或者串行模式。
创建连接时用sqlite3_open_v2()函数的第三个参数来指定线程模式。SQLITE_OPEN_NOMUTEX标识创建多线程模式的连接;SQLITE_OPEN_FULLMUTEX标识创建串行模式的连接。如果没有指定标识,或者使用sqlite3_open()或sqlite3_open16()函数来创建数据库连接,那么在编译时或启动时指定的线程模式将作为默认的线程模式使用。
相关文章
- sqlite database browser的使用「建议收藏」
- 玩转SQLite-11:C语言高效API之sqlite3_prepare系列函数
- python-Python与SQLite数据库-使用Python执行SQLite查询(一)
- 利用SQLite数据库文件实现任意代码执行
- MySQL到SQLite转换:一步到位(mysql转sqlite)
- 的区别SQLite和MySQL: 突出的不同特点(sqlite和mysql)
- 从SQLite到MSSQL:轻松实现数据迁移(sqlite转mssql)
- ite从MSSQL到SQLite的数据迁移之路(mssql转换成sql)
- 保护你的Sqlite数据库(SQLite数据库安全秘籍)
- Android用SQLite实现事务的方法
- SQLite学习手册(SQLite在线备份)
- C++操作SQLite简明教程
- sqlserver,sqlite,access数据库链接字符串整理
- SQLite数据库安装及基本操作指南