android小问题--------------------SQLiteDatabase.insert(table, nullColumnHack, values)参数

本文主要是介绍android小问题--------------------SQLiteDatabase.insert(table, nullColumnHack, values)参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SQLiteDatabase除了可以通过execSQL()直接执行SQL语句之外,还可以通过.insert(table, nullColumnHack, values)方法直接插入操作。

第一个参数为表名,第三个参数为ContentValues实例,以键值对的形式将列和值Put进去然后放入第三个参数为就行了。

那么第二个参数是什么意思,总有人搞不明白,第二个参数的字面意思其实就是:当第三个参数传入null时,第二个参数为什么。也就是说如果第三个参数不为null,那么第二个参数是不起作用的。那这又是为什么,看源码:

因为底层Insert()方法直接调用了insertWithOnConflict()方法,那么就直接贴此方法的源码:

 acquireReference();try {StringBuilder sql = new StringBuilder();sql.append("INSERT");sql.append(CONFLICT_VALUES[conflictAlgorithm]);sql.append(" INTO ");sql.append(table);sql.append('(');Object[] bindArgs = null;int size = (initialValues != null && initialValues.size() > 0)? initialValues.size() : 0;if (size > 0) {bindArgs = new Object[size];int i = 0;for (String colName : initialValues.keySet()) {sql.append((i > 0) ? "," : "");sql.append(colName);bindArgs[i++] = initialValues.get(colName);}sql.append(')');sql.append(" VALUES (");for (i = 0; i < size; i++) {sql.append((i > 0) ? ",?" : "?");}} else {sql.append(nullColumnHack + ") VALUES (NULL");}sql.append(')');

可以看到,此方法其实在底层也是拼接了SQL串。。。所以我说不如直接去学学SQL。。要不不懂SQL的人根本不明白为什么。。其实底层逻辑是这样的,它会根据三个参数拼接出这样的sql语句 insert into tableNmae (......) values(......)  values中的值就由传入的第三个参数拼接出来的,而我们可以看到,如果第三个值传入为Null,那么去执行 

sql.append(nullColumnHack + ") VALUES (NULL");
也就是是说最后拼接出来的SQL为:insert into tableName(null)values(null),这样sql语法就错误的。。会报错。。所以。。就是这样的。


这篇关于android小问题--------------------SQLiteDatabase.insert(table, nullColumnHack, values)参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/527627

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁