mybatis返回自增主键踩坑记
背景
MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
dao传入实体,int insertEntity(Entity entity),其中entity的id为自增主键
调用service方法返回int的值总是为1。
xml配置
<insert id="insertEntity" parameterType="com.xxxx.dto.Entity " keyColumn="id"
useGeneratedKeys="true" keyProperty="id">
INSERT INTO ...
尝试方案
怀疑配置不生效,使用
<selectKey resultType="Integer" keyProperty="id" order="AFTER">
select @@IDENTITY as id
</selectKey>
仍然不行,再换一种
<selectKey resultType="Integer" keyProperty="id" order="AFTER">
SELECT LAST_INSERT_ID()
</selectKey>
仍然不行。
调试
通过在调用插入操作后,不小心查看了entity的值,发现此时id为自增后的值,瞬间明白了,insert返回的值是受影响的行数,插入后的id放入了entity中,取返回后的id值时,需要从entity中去获取。
总结
返回插入的唯一主键是通过实体Entity获取,而不能通过sql执行后的int或long取,因为xml里面sql执行后返回的值是受影响行数.
错误获取插入的唯一主键的方式:
public Result insertEntity(insertEntity entity) {
Long id= dao.insertEntity(entity);
System.out.println(id);
}
正确获取插入的唯一主键的方式,注意:是entity
public Result insertEntity(insertEntity entity) {
dao.insertEntity(entity);
System.out.println(entity.getId());
}
相关文章
- mybatis的缓存策略
- springboot中配置mybatis别名该怎么写?
- Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
- Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
- Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
- Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
- Mybatis下Oracle插入新增返回主键id
- mybatis开始
- Java_myBatis_xml代理写法
- Spring Boot (八): Mybatis 增强工具 MyBatis-Plus
- mybatis做like模糊查询
- mybatis新增时将主键值返回(注解方式)
- MyBatis在insert插入操作时返回主键ID
- Atitit mybatisutil 模块测试功能列表 1.1. mybatis读取mapper配置的sql语句 使用xml类库1 1.2. Mybatis替换参数工具类型3 Itfs pn
- mybatis的mapper返回map结果集(springboot)
- 【MyBatis笔记08】Mybatis中常用的一些操作
- 【MyBatis笔记11】Mybatis中的一级缓存和二级缓存
- Spring MVC 中 引入 Mybatis 的实现方法(一)
- mybatis使用QueryWrapper查询为空的问题,可能是接参的类型为基本变量的数组
- MyBatis之Hello world(Mybatis入门)
- spring中@param和mybatis中@param使用差别
- Spring+SpringMVC+Mybatis(开发必备技能)04、mybatis自动生成mapper_dao_model(包含工具与视频讲解) 纯绿色版本、配套使用视频,100%运行成功
- 使用mybatis-plus来自定义排序