Mybatis如何获取最新插入数据的id

作者:touxianya 时间:2023-02-26 08:15:20 

获取最新插入数据的id

原始方法

读取最后一条的插入数据,但这样会造成如果两条数据同时插入,会并发出现错误

SELECT * FROM admin_users where 1=1 ORDER BY id desc  LIMIT 1
select MAX(id) from admin_users

使用useGeneratedKeys

useGeneratedKeys 取值范围true|false 默认值是:false。

含义:设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中。

直接在注册完成后取id就行

<!--表名-->
    <sql id="tableName">IMS_BS_BOOK_COPY</sql>
    <!--字段-->
    <sql id="insertField">PRICE,ENTITY_ID,CODE,ADD_TIME,STATUS,REASON,GRID_CODE,STALL_CODE,CASE_CODE,ORDER_CODE</sql>
    <!--字段值-->
    <sql id="insertFieldValue">#{PRICE},#{ENTITY_ID},#{CODE},#{ADD_TIME},#{STATUS},#{REASON},#{GRID_CODE},#{STALL_CODE},#{CASE_CODE},#{ORDER_CODE}</sql>
    <!--新增-->
    <insert id="save" parameterType="pd" useGeneratedKeys="true" keyProperty="id">insert into
        <include refid="tableName"/>(
        <include refid="insertField"/>) values (
        <include refid="insertFieldValue"/>)
    </insert>

根据时间查询最新一条数据

第一种的xml配置根据最新的插入时间

<select id="selectLast" resultMap="BaseResultMap" parameterType="java.lang.String">
        SELECT
        *
        from 表名
        where createtime=(select max(createtime) from 表名 where
        字段名=#{参数名,jdbcType=VARCHAR} )
    </select>

第二种的xml配置根据ownum

select id="selectLast" resultMap="BaseResultMap" parameterType="java.lang.String">
            select t.*,rownum from
            (select * from 表名  where  字段名=#{参数名,jdbcType=VARCHAR} 
            order by createtime desc)t   where rownum=1
    </select>

不足之处请大家评论指出。以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

来源:https://blog.csdn.net/touxian51552/article/details/85274246

标签:Mybatis,最新,数据,id
0
投稿

猜你喜欢

  • java代码执行字符串中的逻辑运算方法

    2023-11-29 12:13:06
  • 一步步教你如何使用Java实现WebSocket

    2023-06-07 04:18:20
  • C#关闭指定名字进程的方法

    2021-11-23 23:59:42
  • Android开发新手常见的10个误区

    2021-07-30 02:14:10
  • 基于idea 的 Java中的get/set方法之优雅的写法

    2023-11-26 20:22:50
  • Android安装apk文件并适配Android 7.0详解

    2022-11-11 01:41:28
  • UE4 Unlua 调用异步蓝图节点AIMoveTo函数示例详解

    2022-04-12 05:35:41
  • Android开发解决字符对齐问题方法

    2022-09-15 18:26:15
  • Java超详细教你写一个银行存款系统案例

    2022-01-04 22:33:59
  • EditPlus运行java时从键盘输入数据的操作方法

    2023-04-16 21:18:45
  • 在Winform框架界面中改变并存储界面皮肤样式的方法

    2021-06-08 09:08:24
  • Android通过应用程序创建快捷方式的方法

    2021-07-08 00:41:09
  • Android使用MulticastSocket实现多点广播图片

    2023-01-16 06:13:57
  • Android 13新功能及适配工作详解

    2022-04-13 11:05:33
  • Java基础知识精通二维数组的应用

    2022-02-03 03:01:28
  • Java中使用fileupload组件实现文件上传功能的实例代码

    2021-11-17 09:20:33
  • 详解Spring Boot自动装配的方法步骤

    2023-11-18 15:02:18
  • 字符串阵列String[]转换为整型阵列Int[]的实例

    2021-07-22 08:19:17
  • Unity 修改FBX模型动画的操作

    2023-03-17 17:59:39
  • Android网格布局GridView实现漂亮的多选效果

    2023-10-20 08:52:38
  • asp之家 软件编程 m.aspxhome.com