欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-18 11:19:43
目录获取最新插入数据的id原始方法使用usegeneratedkeys根据时间查询最新一条数据第一种的xml配置根据最新的插入时间第二种的xml配置根据ownum获取最新插入数据的id原始方法读取最后...

获取最新插入数据的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>

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