Mybatis insert方法主鍵回填和自定義操作
在數(shù)據(jù)庫插入的時候,有很多屬性需要我們自己處理,如主鍵自增字段。
MYSQL中主鍵根據(jù)一定規(guī)則生成后,需要我們在插入后去主動獲取,以便后面的操作,Mybatis為我們提供了處理的方法。
主鍵回填
keyProperty:指定哪個字段是主鍵useGeneratedKeys:這個主鍵是否使用數(shù)據(jù)庫內(nèi)置生成策略
我們可以在XML文件中進行如下配置:
<insert id="insertUser" parameterType="user" useGeneratedKeys="true" keProperty="id">
insert into t_user(user_name,age) values (#${userName},#{age})
</insert>
這樣我們傳入的user對象無需設(shè)置id字段,Mybatis會自動進行設(shè)置處理,插入成功后id字段會回填到user對象中。
使用自定義規(guī)則生成主鍵
實際工作上有時候主鍵的生成規(guī)則并不是這么簡單,比如我們?nèi)∠鹴_user的主鍵自增規(guī)則。我們的要求是:
如果t_user表沒有數(shù)據(jù),我們也要設(shè)置主鍵為1,否則就取主鍵最大值加2,來設(shè)置新的主鍵。
對此,Mybatis也提供了處理方法,使用SelectKey元素進行處理
<insert id="insertUser" parameterType="user" useGeneratedKeys="true" keProperty="id">
<SelectKey keProperty="id" resultType="int" order="BEFORE>
select if(max(id) is null, 1, max(id) + 2) as newId from t_user
</SelectKey>
insert into t_user(user_name,age) values (#${userName},#{age})
</insert>
這樣我們就可以根據(jù)自定義的規(guī)則來處理生成主鍵了。
MyBatis中配置主鍵回填
主鍵回填是一個很常見的需求,我們經(jīng)常需要添加完數(shù)據(jù)之后,需要獲取剛剛添加的數(shù)據(jù) id,數(shù)據(jù)庫主鍵回填在 MyBatis 中的簡單實現(xiàn)如下:
useGeneratedKeys設(shè)置為true,keyProperty為要回填的屬性名。
![]()
當(dāng)插入完成后,這個對象的 id 就會被自動賦值,值就是剛剛插入成功的id。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
- mybatis-plus指定字段模糊查詢的實現(xiàn)方法
- springboot?+mybatis?使用PageHelper實現(xiàn)分頁并帶條件模糊查詢功能
- MyBatis中模糊查詢使用CONCAT('%',#{str},'%')出錯的解決
- Mybatis?mysql模糊查詢方式(CONCAT多個字段)及bug
- mybatis?使用concat?模糊查詢方式
- Java Fluent Mybatis 聚合查詢與apply方法詳解流程篇
- mybatis多層嵌套resultMap及返回自定義參數(shù)詳解
- 詳解MyBatis中主鍵回填的兩種實現(xiàn)方式
- Mybatis模糊查詢之三種定義參數(shù)方法和聚合查詢、主鍵回填實現(xiàn)方法
相關(guān)文章
Java后端限制頻繁請求和重復(fù)提交的實現(xiàn)
很多用戶會請求過于頻繁或者是多次重復(fù)提交數(shù)據(jù),本文主要介紹了Java后端限制頻繁請求和重復(fù)提交的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04
mybatis Example的Criteria用法:or與isNull詳解
這篇文章主要介紹了mybatis Example的Criteria用法:or與isNull詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
SSH框架網(wǎng)上商城項目第6戰(zhàn)之基于DataGrid的數(shù)據(jù)顯示
SSH框架網(wǎng)上商城項目第6戰(zhàn)之基于DataGrid的數(shù)據(jù)顯示,提供了豐富的選擇、排序、分組和編輯數(shù)據(jù)的功能支持,感興趣的小伙伴們可以參考一下2016-05-05
SpringBoot將多個文件夾進行壓縮的兩種方法(瀏覽器下載和另存為)
Spring Boot項目通常不會自動對文件夾進行壓縮,不過,在打包應(yīng)用時,如果你使用了Maven或Gradle這樣的構(gòu)建工具,并且配置了相應(yīng)的插件,可以在打成jar或war包的時候?qū)⒁蕾嚨膸煳募喜⒉嚎s,本文介紹了SpringBoot將多個文件夾進行壓縮的兩種方法2024-07-07
SpringBoot項目執(zhí)行腳本 自動拉取最新代碼并重啟的實例內(nèi)容
在本篇文章里小編給大家整理的是一篇關(guān)于SpringBoot項目執(zhí)行腳本 自動拉取最新代碼并重啟的實例內(nèi)容,有需要的朋友們參考下。2019-12-12
詳細分析Java并發(fā)集合ArrayBlockingQueue的用法
這篇文章主要介紹了詳細分析Java并發(fā)集合ArrayBlockingQueue的用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04

