Mybatis如何获取最新插入数据的id
时间:2022-04-08 10:46:48|栏目:JAVA代码|点击: 次
获取最新插入数据的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>
上一篇:解决maven maven.compiler.source和maven.compiler.target的坑
栏 目:JAVA代码
本文标题:Mybatis如何获取最新插入数据的id
本文地址:http://www.codeinn.net/misctech/198581.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




