android sqlite插入与修改tips

本文分享了在使用SQLite数据库时遇到的一些常见问题及解决方法,重点介绍了SQLiteDatabase.insert()函数的使用,包括nullColumnHack参数的作用以及如何避免空行插入错误。同时,对比了直接调用方法与execSQL()、rawQuery()方法的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近做一个练习用的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语句。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值