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