最近做一个练习用的app,频繁使用了数据库。。踩了一些小坑。总结一番吧。
SQLiteDatabase.insert()函数
table: 要插入数据的表的名称
nullColumnHack:当values参数为空或者里面没有内容的时候,我们insert是会失败的(底层数据库不允许插入一个空行),为了防止这种情况,我们要在这里指定一个列名,到时候如果发现将要插入的行为空行时,就会将你指定的这个列名的值设为null,然后再向数据库中插入。
values:一个ContentValues对象,类似一个map.通过键值对的形式存储值。
这里很多人会迷惑,nullColumnHack到底干什么用的,为什么会出现呢。当我们不设定一列的时候,不都是数据库给设为默认值吗?很多字段设置默认值也是null,这里显示的设置也是null,有什么区别吗,怎么会显示设置了之后就允许插入了呢?
------------------------引用自炸斯特
这里最难理解的就是nullColumnHack的作用。我理解的就是,如果不小心插入了空行(不被允许),如果nullColumnHack变量传递了列明,那么这一列就被赋值null。从而允许了插入。
除了使用上面的直接调用方法,
还可以使用SQLiteDatabase。execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句; rawQuery()方法用于执行select语句。