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

本文共 1017 字,大约阅读时间需要 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/sniperLi/blog/416715

你可能感兴趣的文章
行为驱动开发Behaviour Driven Development
查看>>
Struts2中的Blob格式文件上传下载
查看>>
实用window 2008之四:用批处理添加/修改多个域账户
查看>>
LoadRunner在使用时遇到的问题及解决方法
查看>>
Exchange Server 2010 EMC打开报错故障处理
查看>>
8088 汇编速查手册
查看>>
MMO移动游戏性能分析报告:渲染、UI、逻辑代码和内存需重点关注
查看>>
SQL Server 2014新功能 -- 延迟事务持久性(Delayed Transaction Durability)
查看>>
Linux RDS Protocol Local Privilege Escalation
查看>>
mysql——Linux下安装max-4.1.14
查看>>
Spring--Spring容器
查看>>
Redis主从持久化测试
查看>>
scikit-learn学习之K最近邻算法(KNN)
查看>>
目前用的IDE--Eclipse
查看>>
MDSF:SoftFluent敏捷模型驱动开发介绍
查看>>
ORACLE数据库恢复
查看>>
[CTO札记]互联网产品何时上线为佳--客户第一原则 -
查看>>
Enterprise Library 2.0 Hands On Lab 翻译(13):安全应用程序块(二)
查看>>
Idea2016.2.5下安装破解版JRebel 6.4.3
查看>>
MAC环境Cocos Creator中调试JS代码必要设置
查看>>