zoukankan      html  css  js  c++  java
  • 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());

    }

  • 相关阅读:
    WebServices Get
    字符出现次数
    正则
    防止AutoPost
    转双问号,单问号
    GetData
    UpdatePanel
    字居中
    C# 面向对象之多态
    C# 委托之把委托从委托链(多播委托)移除
  • 原文地址:https://www.cnblogs.com/davidwang456/p/12522864.html
Copyright © 2011-2022 走看看