一个关于php和其他程序共享使用同一个sqlite数据库的问题

发布于 2022-09-04 14:31:52 字数 290 浏览 10 评论 0

我搞了个树莓派,树莓派上用qt写了个图形界面,图形界面负责收集一些信息放到sqlite数据库中进行保存。同时我还做了个php页面来读取数据库中的数据,于是问题出现了。由于树莓派性能的问题,每次写数据库耗时较长,而在这期间数据库会被qt的连接器锁住,导致在此期间访问php页面会直接报500错误,日志表明是由于数据库被锁住打开失败。
qt的数据库连接自打开时就建立直至程序进程被结束,php的同时访问量不超过2个。php的话基本不会写操作,大部分是读,写操作很少会用,qt主要是写操作,偶尔也读一下其中的参考数据。想问一下怎样让qt在写的过程中允许php读取呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

天生の放荡 2022-09-11 14:31:53

SQLite是数据库级别的锁定,在写的时候是不能读的.
建议批量写开启事务,性能会有显著提升
php读也可以显式的开启事务,这样不会直接报500错误

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文