理论上简单的sql语句:
CREATE UNIQUE INDEX i1 ON MyTable (col1, col2) WHERE col3 IS NULL;
然而,在尝试执行该语句时,我得到:
android.database.sqlite.SQLiteException: near "WHERE": syntax error: , while compiling: CREATE UNIQUE INDEX
为什么????有没有解决方法?
答案 0 :(得分:7)
我没有在android中使用索引,但它出现在sqlite changelog中,部分索引在SQLite 3.8.0中可用。
我认为大多数Android设备(4.3及之前肯定),使用早期版本的SQLite。在终端模拟器或adb shell中,使用sqlite3 --version
查看您的设备正在运行的SQLite版本。如果它在3.8.0之前,则它不支持部分索引,您将不得不关闭WHERE子句。
实际上,您应该忽略WHERE子句,因为许多用户在发布时不会使用适当的sqlite版本来使用您的应用程序。反正没有必要。