Mybatis如何獲取最新插入數(shù)據(jù)的id
獲取最新插入數(shù)據(jù)的id
原始方法
讀取最后一條的插入數(shù)據(jù),但這樣會造成如果兩條數(shù)據(jù)同時插入,會并發(fā)出現(xiàn)錯誤
SELECT * FROM admin_users where 1=1 ORDER BY id desc ?LIMIT 1 select MAX(id) from admin_users
使用useGeneratedKeys
useGeneratedKeys 取值范圍true|false 默認值是:false。
含義:設(shè)置是否使用JDBC的getGenereatedKeys方法獲取主鍵并賦值到keyProperty設(shè)置的領(lǐng)域模型屬性中。
直接在注冊完成后取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ù)據(jù)
第一種的xml配置根據(jù)最新的插入時間
<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>
不足之處請大家評論指出。以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
- MyBatis批量插入幾千條數(shù)據(jù)為何慎用foreach
- SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫數(shù)據(jù)
- Mybatis?Plus插入數(shù)據(jù)后獲取新數(shù)據(jù)id值的踩坑記錄
- 如何用注解的方式實現(xiàn)Mybatis插入數(shù)據(jù)時返回自增的主鍵Id
- mybatis插入數(shù)據(jù)后如何返回新增數(shù)據(jù)的id值
- MyBatis?實現(xiàn)多對多中間表插入數(shù)據(jù)
- MyBatis實現(xiàn)批量插入數(shù)據(jù),多重forEach循環(huán)
- MyBatis實現(xiàn)插入大量數(shù)據(jù)方法詳解
相關(guān)文章
intellij idea隱藏.iml和.idea等自動生成文件的問題
這篇文章主要介紹了intellij idea隱藏.iml和.idea等自動生成文件的問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09Java 中String StringBuilder 與 StringBuffer詳解及用法實例
這篇文章主要介紹了Java 中String StringBuilder 與 StringBuffer詳解及用法實例的相關(guān)資料,需要的朋友可以參考下2017-02-02mybatis-plus攔截器、字段填充器、類型處理器、表名替換、SqlInjector(聯(lián)合主鍵處理)
本文主要介紹了mybatis-plus攔截器、字段填充器、類型處理器、表名替換、SqlInjector(聯(lián)合主鍵處理),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11一篇文章帶了解如何用SpringBoot在RequestBody中優(yōu)雅的使用枚舉參數(shù)
這篇文章主要介紹了SpringBoot中RequestBodyAdvice使用枚舉參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08SpringBoot整合SpringSecurity認證與授權(quán)
在項目開發(fā)中,權(quán)限認證是很重要的,尤其是一些管理類的系統(tǒng),對于權(quán)限要求更為嚴格,本文主要介紹了SpringBoot整合SpringSecurity認證與授權(quán),感興趣的可以了解一下2023-11-11