一个关于php和其他程序共享使用同一个sqlite数据库的问题
我搞了个树莓派,树莓派上用qt写了个图形界面,图形界面负责收集一些信息放到sqlite数据库中进行保存。同时我还做了个php页面来读取数据库中的数据,于是问题出现了。由于树莓派性能的问题,每次写数据库耗时较长,而在这期间数据库会被qt的连接器锁住,导致在此期间访问php页面会直接报500错误,日志表明是由于数据库被锁住打开失败。
qt的数据库连接自打开时就建立直至程序进程被结束,php的同时访问量不超过2个。php的话基本不会写操作,大部分是读,写操作很少会用,qt主要是写操作,偶尔也读一下其中的参考数据。想问一下怎样让qt在写的过程中允许php读取呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
SQLite是数据库级别的锁定,在写的时候是不能读的.
建议批量写开启事务,性能会有显著提升
php读也可以显式的开启事务,这样不会直接报500错误