打开 sqlite db 文件,open操作成功,查询返回 14 号错误:
"unable to open database file"
有几个困惑的地方:
* db都是从iphone上取下来的,其他几个db都可以正常打开,查询,唯独这个不行。
* 将这个db放在Windows下,用SQLiteExpert可以打开,说明数据库本身没有问题。(当前是在Mac下)
* 将程序提升到root权限执行,database文件可以打开。这又根第一点有点矛盾,为啥只有这个需要权限呢?
带着疑问找到几个相关知识点:
* sqlite打开db的时候,一般会在db文件相同目录生成一个临时文件
* mac下的系统目录创建文件是需要root权限的
* 而我们这个db又刚好是放在系统目录下
尝试了一种解决方案,验证ok
* 如果db能正常打开,忽略
* 如果碰到error 14,那就将dbcopy到非系统目录再次尝试打开。
问题解决,但却没有彻底释疑,为啥就部分db出现这种情况呢?