Sqlite内存数据库在多线程下的使用问题

在Windows平台上,一个全局Sqlite内存数据库在多线程环境中使用时遇到问题。方法一中,所有线程共享一个连接,读写需要同步,影响效率。方法二,将数据库保存到文件,每个线程单独打开,但内存数据库无法通过sqlite_open(":memory:")在不同线程间共享。讨论了Sqlite3_open在内存数据库上的行为,并寻求解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

WINDOWS平台,多线程服务器,我想创建一个全局内存数据库,然后在其他线程里面使用这个库,包括读写,弄的时候发现有几个问题:

1  方法一:程序启动时创建一个全局Sqlite连接,各个线程都可以操作这个实例。但经测试发现,这么做,如果不做同步,读写都会冲突。也就是说,无论读写,只能有一个线程操作该实例,这样未免也太痛苦了,读也需要同步,效率降低太多。

2  方法二:如果把数据库创建到文件,那么可以在创建每个服务线程里面打开这个数据库,然后操作,这样就不需要处理同步了。(读不需要同步,写Sqlite自己做了同步LOCK)
   不过如果把数据库建立到内存,好像就不能这样了:
   全局数据库用sqlite_open(":memory:",&db)创建,但在子线程里面如果也用sqlite_open(":memory:",&db)得到的是一个空数据库。事实上,即使在同一个线程里面这样做:
sqlite3* db1=NULL;
sqlite3* db2=NULL;
sqlite3_open(":memory:",&db1);
//在db1中创建表,填数据等等
sqlite3_open(":memory:",&db2);//这时候得到的db2是一个空的数据库

   在这种情况下如何才能得到先前已经创建的内存数据库?


第 1 楼    xiao_fang(frank)
2006-4-7 17:10:52
得分: 100   返回顶部
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值