sqlite3 - 一个关于php和其他程序共享使用同一个sqlite数据库的问题
高洛峰
高洛峰 2017-04-11 10:07:14
[PHP讨论组]

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

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(1)
ringa_lee

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号