sqlite中文手册 sqlite能不能多线程并发访问?
sqlite能不能多线程并发访问?
作为一个小型嵌入式数据库,SQLite不提供复杂的锁定机制。它不能在内部管理多通道并发下数据操作的同步,更不能进行优化。因此,当涉及到多通道并发时,需要外部读写锁控制,否则SQLite会返回SQLiteBusy错误来拒绝请求。
返回SQLiteuuBusy主要有以下几种情况:
1。当有写操作时,其他的读操作将被拒绝
2。当有写操作时,其他写操作将被拒绝
3。当事务被打开时,在事务被提交之前,其他写操作将被拒绝
4。当一个事务被打开时,在提交该事务之前,其他事务请求将被拒绝
5。当有读操作时,其他写操作将被拒绝
6。基于以上讨论,我们可以看出这是一个典型的读者-作者问题。读操作应该是共享的,写操作应该是互斥的,读操作和写操作也应该是互斥的
可以设计以下解决方案来解决并发操作数据库的锁定问题,并保证读操作可以保持最大的并发性
1。互斥用于控制数据库写入操作。只有具有互斥的线程才能操作数据库
3。写操作必须与互斥无关
4。读取操作必须能够共享互斥锁,即在第一次读取时获取互斥锁,在最后一次读取时释放互斥锁http://blog.csdn.net/bestrem9/文章/细节/6322916
sqlite中文手册 sqlite3并发 sqlite3支持多线程吗
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。