error14,unable to open datebase file

打开 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出现这种情况呢?

 

你可能感兴趣的:(error14,unable to open datebase file)