当表仅包含_id时,Android Sqlite INSERT错误

我有一个仅包含_id的sqlite表:

"create table rule (_id integer primary key);";

运行此命令集时:

ContentValues initialValues = new ContentValues();
mDb.insert(TABLE, null, initialValues)

我得到以下异常:

android.database.sqlite.sqliteException: near "null": Syntax error (code 1): , while compiling: INSERT INTO rule(null) VALUES (NULL)

发生初始错误是因为ContentValues不能为空. Android提供了一个方便的参数,称为nullColumnHack,该参数允许您传递值为null的单个列来绕过此问题.

但是,这不适用于我的情况,因为行ID(_id)不能为null!基于SQLite language docs中的语法,我希望能够运行sqlite代码

INSERT INTO rule DEFAULT VALUES;  

我如何使用android insert方法实现类似的功能?还是我需要添加一些内容到create语句中?

更新:在表只包含一个rowid的情况下,正确的语法是使用INSERT INTO __ DEFAULT VALUES.

android中列出的sqlite插入方法不支持DEFAULT VALUES作为选项.

A bug has been filed with google并获得对认值的支持,需要执行以下命令:

mDb.execsql("INSERT INTO rule DEFAULT VALUES;");
Cursor c = mDb.rawQuery("SELECT last_insert_rowid()",null);
c.movetoFirst();
int rowid = c.getInt(0);

如已接受的答案中所述,我们可以通过使用nullHackColumn并将行ID(_id)分配为null并让sqlite从null转换为自动递增的值来解决此问题(和DEFAULT VALUES).

解决方法:

正如前面提到的,您可以提供nullColumnHack作为第二个参数.正如您自己所提到的,自动增量对于增加主键的值不是必需的.
所以语法:

insert into rule (_id) values(null)

其中_id是主键,自动递增的值对于sql是正确的.我认为大多数sql数据库将用新的递增值替换null,至少MysqL,sqlite和Oracle可以做到这一点

从而:

ContentValues cv = new ContentValues();
db.insert("rule", "_id", cv);

应该给您想要的结果.

相关文章

SQLite架构简单,又有Json计算能力,有时会承担Json文件/RES...
使用Python操作内置数据库SQLite以及MySQL数据库。
破解微信数据库密码,用python导出微信聊天记录
(Unity)SQLite 是一个软件库,实现了自给自足的、无服务器...
安卓开发,利用SQLite实现登陆注册功能