【问题标题】:Absurd SQLite Error in ICSICS 中的荒谬 SQLite 错误
【发布时间】:2012-08-31 00:23:40
【问题描述】:
我已经使用here 的修改实现了找到here 的代码。
在 Android 2.2 模拟器上似乎一切正常,但是在实际的 ICS 设备和 Jellybean 模拟器上,我似乎遇到了以下(奇怪的)错误:
android.database.sqlite.SQLiteException:无法将数据库从版本 300300 降级到 12
我的数据库版本不可能是 300300,我已经尝试删除并重新安装应用程序,但似乎没有什么不同。关于为什么会发生这种情况的任何线索?
【问题讨论】:
标签:
android
sqlite
android-4.0-ice-cream-sandwich
【解决方案1】:
不久前我也遇到了同样的问题。它似乎只发生在某些设备上,这些设备似乎编译了内置 SQLite 库,默认情况下打开了预写日志 (WAL)。
当您尝试以只读模式打开数据库时,这会导致问题,因为启用了 WAL 的数据库无法以只读模式打开。解决方案是避免使用任何试图以只读模式打开数据库的 SQLite API,例如 getReadableDatabase 或 SQLiteDatabase.OPEN_READONLY 标志。相反,请尝试在 Android 上打开 SQLite 数据库时使用 getWritableDatabase 或 SQLiteDatabase.OPEN_READWRITE 标志。