Android开发12——Andorid中操作数据库的insert的两种方法以及nullColumnHack

简介:

一、发现问题

先看两种方法插入数据

 
  1. public void save(Person p)  
  2. {  
  3.  SQLiteDatabase db = dbHelper.getWritableDatabase();  
  4.  db.execSQL("insert into person(name,phone) values (?,?)"new Object[] { p.getName(), p.getPhone() });  
  5.  db.close();  
  6. }  
  7.  
  8. public void save(Person p)  
  9. {  
  10.  SQLiteDatabase db = dbHelper.getWritableDatabase(); // 取得数据库操作实例  
  11.  ContentValues values = new ContentValues();  
  12.  values.put("name", p.getName());  
  13.  values.put("phone", p.getPhone());  
  14.  db.insert("person""name", values);  
  15.  db.close();  
  16. }  
  17.  

这两种方法可读性都比较好,但我们注意到db.insert("person", "name", values);操作中有一个name字段是什么意思呢?

 


二、解决问题

insert的一种构造方法

 
  1. public long insert (String table, String nullColumnHack, ContentValues values)  
  2.  

table

要插入数据的表的名称

values

ContentValues对象,类似一个map通过键值对的形式存储值。

nullColumnHack

当values参数为空或者里面没有内容的时候,insert是会失败的(底层数据库不允许插入一个空行),为了防止这种情况,要在这里指定一个列名,到时候如果发现将要插入的行为空行时,就会将你指定的这个列名的值设为null,然后再向数据库中插入。通过观察源码的insertWithOnConflict方法可以看到当ContentValues类型的数据initialValues为null或size<=0时,就会在sql语句中添加nullColumnHack的设置。

若不添加nullColumnHack则sql语句最终的结果将会类似insert into tableName()values();这是不允许的。

若添加上nullColumnHack则sql语句将会变成insert into tableName (nullColumnHack)values(null);这是可以的。

参考地址:http://mofan.iteye.com/blog/1412262

本文转自IT徐胖子的专栏博客51CTO博客,原文链接http://blog.51cto.com/woshixy/1083605如需转载请自行联系原作者


woshixuye111

相关文章
|
5天前
|
存储 安全 Android开发
安卓应用开发:构建一个高效的用户登录系统
【5月更文挑战第3天】在移动应用开发中,用户登录系统的设计与实现是至关重要的一环。对于安卓平台而言,一个高效、安全且用户体验友好的登录系统能够显著提升应用的用户留存率和市场竞争力。本文将探讨在安卓平台上实现用户登录系统的最佳实践,包括对最新身份验证技术的应用、安全性考量以及性能优化策略。
|
8天前
|
前端开发 Android开发 iOS开发
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
【4月更文挑战第30天】Flutter 框架实现跨平台移动应用,通过一致的 UI 渲染(Skia 引擎)、热重载功能和响应式框架提高开发效率和用户体验。然而,Android 和 iOS 的系统差异、渲染机制及编译过程影响性能。性能对比显示,iOS 可能因硬件优化提供更流畅体验,而 Android 更具灵活性和广泛硬件支持。开发者可采用代码、资源优化和特定平台优化策略,利用性能分析工具提升应用性能。
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
|
1天前
|
程序员 Android开发
Android亮度调节的几种实现方法
Android亮度调节的几种实现方法
6 0
|
1天前
|
机器学习/深度学习 Java Shell
[RK3568][Android12.0]--- 系统自带预置第三方APK方法
[RK3568][Android12.0]--- 系统自带预置第三方APK方法
8 0
|
1天前
|
Shell Android开发
Android Activity重写dump方法实现通过adb调试代码
Android Activity重写dump方法实现通过adb调试代码
7 0
|
1天前
|
Android开发
Android APP 隐藏系统软键盘的方法
Android APP 隐藏系统软键盘的方法
5 0
|
1天前
|
Android开发 Kotlin
Kotlin开发Android之基础问题记录
Kotlin开发Android之基础问题记录
9 1
|
1天前
|
Java Android开发
Android开发@IntDef完美替代Enum
Android开发@IntDef完美替代Enum
7 0
|
1天前
|
Android开发
Android中去掉ActionBar的几种方法
Android中去掉ActionBar的几种方法
7 0
|
2天前
|
Android开发
Android 盒子开发过程中遇到的问题及解决方法
Android 盒子开发过程中遇到的问题及解决方法
7 2