代码改变世界
[登录 · 注册]
  • mybatis返回自增主键踩坑记
  • 背景

    MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

    mybatis返回自增主键踩坑记
    使用传统的代码结构controller-->service-->dao

    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());

    }

  • 【推广】 阿里云小站-上云优惠聚集地(新老客户同享)更有每天限时秒杀!
    【推广】 云服务器低至0.95折 1核2G ECS云服务器8.1元/月
    【推广】 阿里云老用户升级四重礼遇享6.5折限时折扣!
  • 原文:https://www.cnblogs.com/davidwang456/p/12522864.html
走看看 - 开发者的网上家园