作者热门文章
- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我的应用程序使用数据库并且在所有 Android 设备上运行良好。
最近一些用户指出它在 HTC Tattoo 上崩溃。我决定试一试,借了一个。
因此,当我调用时出现错误:this.getWritableDatabase();
09-27 18:26:22.292: ERROR/Database(1537): sqlite3_open_v2("/data/data/com.xxx.xxx/databases/radars.db", &handle, 6, NULL) failed
09-27 18:26:22.292: WARN/System.err(1537): android.database.sqlite.SQLiteException: unable to open database file
而且我已经检查过,数据库在设备中:
我真的不明白发生了什么......
非常感谢您的帮助!
编辑:
正如 LAS_VEGAS 所注意到的
# sqlite3 /data/data/com.xxx.xxx/databases/radars.db
给出这个结果:
sqlite3: not found
似乎 HTC Tattoo 有严重的 SQL 问题:
adb shell
# cd /system/xbin
# ls | grep sqlite3//Nothing//
最佳答案
这很奇怪。我认为当您尝试同时从多个线程访问数据库文件时可能会发生这种情况。难道是这样吗?
同样出于测试目的,您是否尝试了 getReadableDatabase()
,也许它提供了线索...
编辑:
你可以从远程 shell 访问吗?:
http://developer.android.com/guide/developing/tools/adb.html#sqlite
编辑 2:
所以HTC tattoo好像没有sqlite3。
关于android - 为什么 getWritableDatabase 在某些设备上崩溃? (sqlite3_open_v2 ... 失败),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7572539/
我是一名优秀的程序员,十分优秀!