Mybatis insert方法主鍵回填和自定義操作
在數(shù)據(jù)庫(kù)插入的時(shí)候,有很多屬性需要我們自己處理,如主鍵自增字段。
MYSQL中主鍵根據(jù)一定規(guī)則生成后,需要我們?cè)诓迦牒笕ブ鲃?dòng)獲取,以便后面的操作,Mybatis為我們提供了處理的方法。
主鍵回填 keyProperty:指定哪個(gè)字段是主鍵 useGeneratedKeys:這個(gè)主鍵是否使用數(shù)據(jù)庫(kù)內(nèi)置生成策略我們可以在XML文件中進(jìn)行如下配置:
<insert parameterType='user' useGeneratedKeys='true' keProperty='id'> insert into t_user(user_name,age) values (#${userName},#{age})</insert>
這樣我們傳入的user對(duì)象無(wú)需設(shè)置id字段,Mybatis會(huì)自動(dòng)進(jìn)行設(shè)置處理,插入成功后id字段會(huì)回填到user對(duì)象中。
使用自定義規(guī)則生成主鍵實(shí)際工作上有時(shí)候主鍵的生成規(guī)則并不是這么簡(jiǎn)單,比如我們?nèi)∠鹴_user的主鍵自增規(guī)則。我們的要求是:
如果t_user表沒(méi)有數(shù)據(jù),我們也要設(shè)置主鍵為1,否則就取主鍵最大值加2,來(lái)設(shè)置新的主鍵。
對(duì)此,Mybatis也提供了處理方法,使用SelectKey元素進(jìn)行處理
<insert 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ī)則來(lái)處理生成主鍵了。
MyBatis中配置主鍵回填主鍵回填是一個(gè)很常見(jiàn)的需求,我們經(jīng)常需要添加完數(shù)據(jù)之后,需要獲取剛剛添加的數(shù)據(jù) id,數(shù)據(jù)庫(kù)主鍵回填在 MyBatis 中的簡(jiǎn)單實(shí)現(xiàn)如下:
useGeneratedKeys設(shè)置為true,keyProperty為要回填的屬性名。

當(dāng)插入完成后,這個(gè)對(duì)象的 id 就會(huì)被自動(dòng)賦值,值就是剛剛插入成功的id。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 如何安裝MySQL 壓縮包2. MariaDB中1045權(quán)限錯(cuò)誤導(dǎo)致拒絕用戶訪問(wèn)的錯(cuò)誤解決方法3. Sql Server 壓縮數(shù)據(jù)庫(kù)日志文件的方法4. Oracle數(shù)據(jù)庫(kù)的兩種授權(quán)收費(fèi)方式詳解5. 實(shí)例講解MySQL 慢查詢6. 關(guān)于Oracle的Dual表7. DB2數(shù)據(jù)庫(kù)控制中心亂碼問(wèn)題解決方法集合8. 詳解MySQL 慢查詢9. 簡(jiǎn)化 DB2 for i5/OS 索引建議10. MySQL存儲(chǔ)過(guò)程的查詢命令介紹

網(wǎng)公網(wǎng)安備