Mybatis useGeneratedKeys 填充自增主键值(使用Mysql)的原理分析
一、Mybatis配置
<insert id="insert" parameterType="com.test.TestDO"
keyProperty="id" useGeneratedKeys="true">
useGeneratedKeys=“true”时 , mybatis会将自增ID值 填充到 TestDO对象中的 id (keyProperty指定)属性。
二、JDBC
java.sql.Statement对象 执行 executeUpdate
int executeUpdate(String sql, int autoGeneratedKeys) throws SQLException;
其中, returnGenerateKeys 的枚举定义在java.sql.Statement中
int RETURN_GENERATED_KEYS = 1; int NO_GENERATED_KEYS = 2;
指定为 RETURN_GENERATED_KEYS时,JDBC 协议要求JDBC实现能返回 自增主键的值。
通过java.sql.Statement对象的 getGeneratedKeys()方法可以取得 包含自增主键值的 ResultSet对象。
三、Mysql
Mysql JDBC 在执行 executeUpdate 时,
mysql server服务器返回的数据包(ResultSetImpl对象)中 包含了两个相关的值:
/** How many rows were affected by UPDATE/INSERT/DELETE? */
protected long updateCount; /** Value generated for AUTO_INCREMENT columns */
protected long updateId = -1; //此次插入的第一个自增ID值(单条插入,批量插入相同)
有了这两个值, 在getGeneratedKeys()时, 从updateId 开始 ,加 updateCount 次,便得到了此次
插入的所有自增ID值。
比如: 数据库自增ID 当前是 99, 通过JDBC批量插入5条数据,执行插入后,updateId值为100, updateCount为5;
那么getGeneratedKeys()返回的ResultSet对象中包含的自增ID 为 100,101,102,103,104 。
单条插入的好理解一点,对于批量插入的如何理解 值的连续性呢 ?
对于Mysql, 包含自增主键的表 对 有一个特殊的表锁,可以理解为自增主键列锁,insert语句执行前需要获取该锁(不影响update操作),
也就是当批量插入(insert ..values 形式 或 Statement.executeBatch() )时,不会有别的插入操作会进来,所以可以保证 批量插入的自增ID值是连续的。
四、Mybatis
Mybatis 利用 JDBC协议中 该机制,在批量插入(接收List<TestDO>对象) 时,根据getGeneratedKeys()的返回接口,顺序写入List中的TestDO对象中。
时间比较仓促,写的比较粗糙,不够详细,不过 大致 原理逻辑 理清楚了。
至于JDBC为何要规定单独接口获取自增主键ID, 又为何在executeUpdate中将 是否返回自增主键值 作为附加参数,
Mysql 如何封装JDBC协议数据包, 如何实现自增主键的表级锁等等,还请见谅。
文中有不当之处,还望各位大佬斧正。
Mybatis useGeneratedKeys 填充自增主键值(使用Mysql)的原理分析的更多相关文章
- MyBatis映射文件1(增删改、insert获取自增主键值)
增删改 Mybatis为我们提供了<insert>.<update>.<delete>标签来对应增删改操作 在接口中写增删改的抽象方法 void addEmp(Em ...
- Mybatis获取数据库自增主键
一般我们都为将表中主键列设置为自增,当我们执行插入语句时,比如这样 //测试添加 Employee employee = new Employee(null, "jerry4",n ...
- 深入分析Mybatis 使用useGeneratedKeys获取自增主键
摘要 我们经常使用useGenerateKeys来返回自增主键,避免多一次查询.也会经常使用on duplicate key update,来进行insertOrUpdate,来避免先query 在i ...
- mybatis插入数据并获取主键值
有时候我们的主键是自增的,但是我们想要在插入一条数据以后获取这条数据的主键值,而我们知道,mybatis执行完插入操作以后返回的是生效的记录数.那如何才能获取这个主键值呢. 1.在配置文件mapper ...
- MySQL 插入与自增主键值相等的字段 与 高并发下保证数据准确的实验
场景描述: 表t2 中 有 自增主键 id 和 字段v 当插入记录的时候 要求 v与id 的值相等(按理来说这样的字段是需要拆表的,但是业务场景是 只有某些行相等 ) 在网上搜的一种办法是 先获取 ...
- mybatis 插入数据并返回主键值
<insert id="insert" parameterType="com.pojo.TSubject" useGeneratedKeys=" ...
- Mybatis获取自增主键值
1.配置文件变化 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLI ...
- SQL Server 插入数据后获得自增主键值
通过SQLServer系统自带函数获取 String sql = "insert into goods values('" + TextBox1.Text + "',&q ...
- mybatis标签selectkey无法返回主键值
随机推荐
- python 开发接口(一)
一.首先导入模块 pip install flask 二 1 import flas 2 import json import flask #1.启动一个服务 #2.接收到客户端传过来的数据 #3. ...
- win10家庭版,双击bat文件无法运行(double click bat file does not execute)
win10家庭版,双击bat文件无法运行,弹出文件打开方式选择框. 在网上搜索处理办法,试了以下方法1-5都没有成功,用方法6规避. 方法1:打开一个驱动器,点“工具-文件夹选项→文件类型→新建→扩展 ...
- AX2012 ERP Excel报表方案
AX提供了丰富的报表方式,内置X++开发的报表.基于微软ReportingService的报表.每个界面都可以导出Excel.Management Reporter.实施ERP最主要的二开工作就是完成 ...
- dubbo 调用服务超时
先贴出错误报告: Failed to invoke the method *** in the service ***. Tried times of the providers [] (/) on ...
- SQL中的排名函数(ROW_NUMBER、RANK、DENSE_RANK、NTILE)简介
排名函数是Sql Server2005新增的功能,下面简单介绍一下他们各自的用法和区别. 在使用排名函数的时候需要注意以下三点: 1.排名函数必须有 OVER 子句. 2.排名函数必须有包含 ORDE ...
- Redis 认识与安装
1. redis是一种Nosql数据库,使用key-value存储数据,因为基于内存存储,所以可以用来做缓存(mysql等数据库是基于表基于数据库的) 2. 和memcathed的区别 redis会生 ...
- Linq to SQL -- Insert、Update、Delete
Insert/Update/Delete操作 插入(Insert) 1.简单形式 说明:new一个对象,使用InsertOnSubmit方法将其加入到对应的集合中,使用SubmitChanges()提 ...
- java——collection总结
Collection 来源于Java.util包,是非常实用常用的数据结构!!!!!字面意思就是容器.具体的继承实现关系如下图,先整体有个印象,再依次介绍各个部分的方法,注意事项,以及应用场景. ...
- 封装poi导出篇
前言 先写的导入,以为导出会很简单,没想到导出的东西也不少,基于常用的几种样式和校验写了一个简单的导出,包括时间,数字,文字长度,下拉框,提示框校验,基础样式包括字体,字体颜色,背景颜色等功能,可以使 ...
- pandas数据结构之series操作
阅读之前假定你已经有了python内置的list和dict的基础.这里内容几乎是官方文档的翻译版本. 概览: 原来的文档是在一个地方,那边的代码看起来舒服些 https://www.y ...