博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis获取当前插入记录的id
阅读量:6950 次
发布时间:2019-06-27

本文共 1018 字,大约阅读时间需要 3 分钟。

hot3.png

问题:mybatis会自动生成一个insert方法如(用的是MySQL数据库):

  <insert id="insert" parameterType="cn.hnne.iclt.model.Task" >

    <selectKey resultType="java.lang.Integer" keyProperty="ictl_otaid" order="BEFORE" >
      SELECT LAST_INSERT_ID() AS ID
    </selectKey>
    insert into .....)
    values (...)
  </insert>

但是直接调用此方法,在记录插入之后在去getTaskID(),得到的是null或者0。

在网上查了很多资料都没有真正解决方案,没有写到实处的,现在写下自己总结分享一下大笑

先分析原理再给出解决办法

insert这几个字段:resultType是查询进行select映射的时候返回类型。其中配置文件中的parameterType是可以不配置的,mybatis会自动传入的。这两个不是重点。

selectKey是返回主键,在Action获得主键就是通过get方法就可以拿到task.getTaskID(),但是有时自动生成的拿不到;

解决:1、里面的keyProperty="otaid"的字段与实体(model)的属性对应,这是mybatis的映射机制。

           2、SELECT LAST_INSERT_ID() AS ID,不是数据库的属性字段名,同样要给model中的实体属性名。

          3、 Order="BEFORE" 如果 是Before那个拿到的是插入前的主键,那么就是初始值null或者是0。

                        那么把它设置after,那就是拿到插入后自动增长的主键值。

下面是修改后的Mapper.xml的代码。

<insert id="insert" parameterType="cn.hnne.iclt.model.Task" >

    <selectKey resultType="int" keyProperty="otaid" order="AFTER" >
      SELECT LAST_INSERT_ID() AS otaid
    </selectKey>
    insert into .....
  </insert>

转载于:https://my.oschina.net/u/1256344/blog/159703

你可能感兴趣的文章
Can't connect to X11 window server using 'localhos
查看>>
redis 介绍与安装
查看>>
letdown
查看>>
Action以外的类中来获得Spring所管理的Service对象
查看>>
Linux系统下手把手完成无人值守安装服务
查看>>
pyfa的汉化
查看>>
使用@Transactional(SUPPORTS)和不加@Transactional 有什么区别?
查看>>
JS判断一个页面是否已经打开
查看>>
TPS和QPS的区别
查看>>
设计模式--模板方法模式
查看>>
Removing Nesting By Returning Early
查看>>
Jfinal weixin源码分析---碎碎念(看最后,有福利)
查看>>
[Java]HashMap的两种排序方式
查看>>
C++中const与指针、引用的分析(转自china_unix GP-King)
查看>>
mysql 保存emoji 4字节宽度字符串
查看>>
diff结果分析
查看>>
php UUID &分布式生成用不重复的随机数方法
查看>>
C语言中强制转换问题
查看>>
python--练习--for i in range(2,101)
查看>>
每天一个linux命令(25):chgrp命令
查看>>