MySQL LAST_INSERT_ID()用法
last_insert_id()函数是适用于id为自动生成的表
下面是插入表数据时last_insert_id()函数的两种用法:
表结构:


此表使用last_insert_id()函数的字段为parentId(父节点);
parentId取值特点:
1)levelId节点为'0'时parentId为空;
2)levelId节点为'1'时parentId取levelId节点为'0'数据的autoId;
3)levelId节点为'2'时parentId取levelId节点为'1'数据的autoId;
1、插入的数据是逐条插入
如:
INSERT INTO sn_app_label (app_code, apply_id, apply_name, level_id, parent_id , state, operation_time)
VALUES ('SNSC', 'G001', '门店属性标签', '', '' , '', '2018-06-15 00:00:00'); INSERT INTO sn_app_label (app_code, apply_id, apply_name, level_id, parent_id , state, operation_time)
VALUES ('SNSC', '', '门店类型', '', (SELECT LAST_INSERT_ID()) , '', '2018-06-15 00:00:00'); INSERT INTO sn_app_label (app_code, apply_id, apply_name, level_id, parent_id , state, operation_time)
VALUES ('SNSC', '', '门店类型', '', (SELECT LAST_INSERT_ID()) , '', '2018-06-15 00:00:00'); INSERT INTO sn_app_label (app_code, apply_id, apply_name, level_id, parent_id , state, operation_time)
VALUES ('SNSC', '', '门店类型', '', (SELECT a.parent_id FROM (SELECT parent_id FROM sn_app_label WHERE app_code = 'SNSC' AND auto_id in (SELECT LAST_INSERT_ID())) a) , '', '2018-06-15 00:00:00');
上面sql可以看到:第一条数据level_id节点为'0',parent_id为空;第二条数据level_id节点为'1',此时parent_id应为第一条数据的auto_id,直接使用sql:select last_insert_id()查询上一条数据的auto_id;第三条数据同第二条;有sql可以看出第四条数据和第三条数据是在同一节点,使用select last_insert_id()查出第三条数据auto_id,再根据auto_id查询第三条的parent_id即可,因为第四条和第三条的parent_id值是一致的。select last_insert_id()查询i结果是集合,故在使用select last_insert_id()结果当做查询条件时使用in()。
上述sql执行结果为:

2、批量插入
如:
INSERT INTO sn_app_label (app_code, apply_id, apply_name, level_id, parent_id , state, operation_time)
VALUES ('SNSC', 'G001', '门店属性标签', '', '' , '', '2018-06-15 00:00:00'),
('SNSC', '', '门店类型', '', (SELECT LAST_INSERT_ID()) , '', '2018-06-15 00:00:00'),
('SNSC', '', '门店类型', '', (SELECT LAST_INSERT_ID()) , '', '2018-06-15 00:00:00'),
('SNSC', '', '门店类型', '', (SELECT a.parent_id FROM (SELECT parent_id FROM sn_app_label WHERE app_code = 'SNSC' AND auto_id in (SELECT LAST_INSERT_ID())) a) , '', '2018-06-15 00:00:00');
sql执行结果:

有执行结果可以看出:select last_insert_id()的结果为之前插入最后一条数据的auto_id,所以第6、7行中parent_id显示的是第四行的auto_id,第8行的parent_id为第四行中的parent_id。
总结:id为自动生成的表;多条语句插入时last_insert_id()获取的是最近一次insert的auto_id;一条语句插入多个值时last_insert_id()获取的也是最近一次insert的auto_id,而不是该批量插入的最近一次intert的auto_id。
MySQL LAST_INSERT_ID()用法的更多相关文章
- 【转载】 mysql explain用法
		
转载链接: mysql explain用法 官网说明: http://dev.mysql.com/doc/refman/5.7/en/explain-output.html 参数: htt ...
 - 知识点:Mysql 基本用法之存储过程
		
存储过程 一. 介绍 存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中,通过调用它的名字可以执行其内部的一堆sql 使用存储过程的优点: 用于替代程序写的SQL语句,实现程序与sql ...
 - 知识点:Mysql 基本用法之视图
		
视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的临时 ...
 - 知识点:Mysql 基本用法之流程控制
		
流程控制 一. 条件语句 if 语句实例: delimiter // CREATE PROCEDURE proc_if () BEGIN declare i int default 0; if i = ...
 - 知识点:Mysql 基本用法之函数
		
函数 MySQL中提供了许多内置函数 例如: sql 内置函数: 一.数学函数 ROUND(x,y) 返回参数x的四舍五入的有y位小数的值 RAND() 返回0到1内的随机值,可以通过提供一个参数(种 ...
 - 知识点:Mysql 基本用法之触发器
		
触发器 使用触发器可以定制用户对表进行[增.删.改]操作时前后的行为 注意:没有查询 一 .创建触发器 触发器基础语法: # 插入前 CREATE TRIGGER tri_before_insert_ ...
 - 知识点:Mysql 基本用法之事务
		
事务 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 事务实例: create table user( id int primar ...
 - Mysql基本用法-存储引擎-04
		
MYSQL中只有 INNODB和BDB 类型的数据表才能支持事务处理!其他的类型是不支持的!(切记!) Mysql基本用法-存储引擎-02中的test_user表 和 phpcvs表 <?php ...
 - MySQL 获取最后插入的ID LAST_INSERT_ID用法
		
LAST_INSERT_ID() 自动返回最后一个INSERT或 UPDATE 查询中 AUTO_INCREMENT列设置的第一个表发生的值. MySQL的LAST_INSERT_ID的注意事项: 第 ...
 
随机推荐
- DTServiceHubClient failed to bless service hub for simulator iPhone X (5C15AE72-12E2-475D-9C2B-EF...
			
XCode跑不起模拟器,并报错:DTServiceHubClient failed to bless service hub for simulator iPhone X (5C15AE72-12E2 ...
 - [原]DOM、DEM、landcover,从tms服务发布格式转arcgis、google服务发布格式
			
原作:南水之源 先看看tms和google服务器发布数据的数据排列:(goole地图与arcgis一样) 我现在手上有tms发布的数据,dom,dem等,现在要用arcgis server来发布这些数 ...
 - Dart集合
			
/* List里面常用的属性和方法: 常用属性: length 长度 reversed 翻转 isEmpty 是否为空 isNotEmpty 是否不为空 常用方法: add 增加 addAll 拼接数 ...
 - Java二维数组的应用
			
package com.imooc; public class ArrayDemo5 { public static void main(String[] args) { //二维数组的声明和创建: ...
 - 解决:error: Cannot find libmysqlclient_r under /usr/local/mysql.
			
libodb-mysql-2.4.0.tar.gz 解压完安装libodb-mysql时,执行完./cofigure后,出现如下错误: checking for libmysqlclient_r... ...
 - python 判断文件是否存在和删除文件的api (其中判断文件在不在让想起这个可以强兼容jenkins工作目录那个问题)
			
判断文件在不在的api: os即operating system(操作系统),Python 的 os 模块封装了常见的文件和目录操作. os.path模块主要用于文件的属性获取,exists是“存在” ...
 - Docker容器(四)——常用命令
			
(1).基本使用方法 查看所有镜像.docker images [root@youxi1 ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE ...
 - [转]如何更换 Ubuntu 18.04 LTS 的 GDM 登录界面背景
			
链接地址:https://www.linuxprobe.com/ubuntu-gdm-login.html
 - 10点睛Spring MVC4.1-全局异常处理
			
10.1 全局异常处理 使用@ControllerAdvice注解来实现全局异常处理; 使用@ControllerAdvice的属性缩小处理范围 10.2 演示 演示控制器 package com.w ...
 - vue-cli3.0和element-ui及axios的安装使用
			
一.利用vue-cli3快速搭建vue项目 Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.有三个组件: CLI:@vue/cli 全局安装的 npm 包,提供了终端里的vue命令( ...