Mybatis如何獲取最新插入數(shù)據(jù)的id
獲取最新插入數(shù)據(jù)的id
原始方法
讀取最后一條的插入數(shù)據(jù),但這樣會(huì)造成如果兩條數(shù)據(jù)同時(shí)插入,會(huì)并發(fā)出現(xiàn)錯(cuò)誤
SELECT * FROM admin_users where 1=1 ORDER BY id desc ?LIMIT 1 select MAX(id) from admin_users
使用useGeneratedKeys
useGeneratedKeys 取值范圍true|false 默認(rèn)值是:false。
含義:設(shè)置是否使用JDBC的getGenereatedKeys方法獲取主鍵并賦值到keyProperty設(shè)置的領(lǐng)域模型屬性中。
直接在注冊(cè)完成后取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>根據(jù)時(shí)間查詢最新一條數(shù)據(jù)
第一種的xml配置根據(jù)最新的插入時(shí)間
<select id="selectLast" resultMap="BaseResultMap" parameterType="java.lang.String">
? ? ? ? SELECT
? ? ? ? *
? ? ? ? from 表名
? ? ? ? where createtime=(select max(createtime) from 表名 where
? ? ? ? 字段名=#{參數(shù)名,jdbcType=VARCHAR} )
? ? </select>第二種的xml配置根據(jù)ownum
select id="selectLast" resultMap="BaseResultMap" parameterType="java.lang.String">
? ? ? ? ? ? select t.*,rownum from
? ? ? ? ? ? (select * from 表名 ?where ?字段名=#{參數(shù)名,jdbcType=VARCHAR}?
? ? ? ? ? ? order by createtime desc)t ? where rownum=1
? ? </select>不足之處請(qǐng)大家評(píng)論指出。以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- MyBatis批量插入幾千條數(shù)據(jù)為何慎用foreach
- SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫數(shù)據(jù)
- Mybatis?Plus插入數(shù)據(jù)后獲取新數(shù)據(jù)id值的踩坑記錄
- 如何用注解的方式實(shí)現(xiàn)Mybatis插入數(shù)據(jù)時(shí)返回自增的主鍵Id
- mybatis插入數(shù)據(jù)后如何返回新增數(shù)據(jù)的id值
- MyBatis?實(shí)現(xiàn)多對(duì)多中間表插入數(shù)據(jù)
- MyBatis實(shí)現(xiàn)批量插入數(shù)據(jù),多重forEach循環(huán)
- MyBatis實(shí)現(xiàn)插入大量數(shù)據(jù)方法詳解
相關(guān)文章
利用maven命令指定配置文件打包springboot項(xiàng)目
這篇文章主要介紹了利用maven命令指定配置文件打包springboot項(xiàng)目,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
win10操作系統(tǒng)下重啟電腦java環(huán)境變量失效
這篇文章主要介紹了win10操作系統(tǒng)下重啟電腦java環(huán)境變量失效,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
springboot用thymeleaf模板的paginate分頁完整代碼
本文根據(jù)一個(gè)簡(jiǎn)單的user表為例,展示 springboot集成mybatis,再到前端分頁完整代碼,需要的朋友可以參考下2017-07-07
springboot無法從靜態(tài)上下文中引用非靜態(tài)變量的解決方法
這篇文章主要介紹了springboot無法從靜態(tài)上下文中引用非靜態(tài)變量的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-06-06
SpringData Repository Bean方法定義規(guī)范代碼實(shí)例
這篇文章主要介紹了SpringData Repository Bean方法定義規(guī)范代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08

