久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Mybatis insert方法主鍵回填和自定義操作

瀏覽:8日期:2023-10-18 17:25:37

在數(shù)據(jù)庫插入的時候,有很多屬性需要我們自己處理,如主鍵自增字段。

MYSQL中主鍵根據(jù)一定規(guī)則生成后,需要我們在插入后去主動獲取,以便后面的操作,Mybatis為我們提供了處理的方法。

主鍵回填 keyProperty:指定哪個字段是主鍵 useGeneratedKeys:這個主鍵是否使用數(shù)據(jù)庫內(nèi)置生成策略

我們可以在XML文件中進行如下配置:

<insert parameterType='user' useGeneratedKeys='true' keProperty='id'> insert into t_user(user_name,age) values (#${userName},#{age})</insert>

這樣我們傳入的user對象無需設置id字段,Mybatis會自動進行設置處理,插入成功后id字段會回填到user對象中。

使用自定義規(guī)則生成主鍵

實際工作上有時候主鍵的生成規(guī)則并不是這么簡單,比如我們?nèi)∠鹴_user的主鍵自增規(guī)則。我們的要求是:

如果t_user表沒有數(shù)據(jù),我們也要設置主鍵為1,否則就取主鍵最大值加2,來設置新的主鍵。

對此,Mybatis也提供了處理方法,使用SelectKey元素進行處理

<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ī)則來處理生成主鍵了。

MyBatis中配置主鍵回填

主鍵回填是一個很常見的需求,我們經(jīng)常需要添加完數(shù)據(jù)之后,需要獲取剛剛添加的數(shù)據(jù) id,數(shù)據(jù)庫主鍵回填在 MyBatis 中的簡單實現(xiàn)如下:

useGeneratedKeys設置為true,keyProperty為要回填的屬性名。

Mybatis insert方法主鍵回填和自定義操作

當插入完成后,這個對象的 id 就會被自動賦值,值就是剛剛插入成功的id。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

相關文章:
主站蜘蛛池模板: 亚洲欧美另类在线观看 | 日日做夜夜爽毛片麻豆 | 成人在线观 | 99精品视频免费在线观看 | 久草福利在线视频 | 中文二区 | 国产在线网站 | 噜噜噜噜噜色 | 97视频久久 | 亚洲日本欧美 | 日日骚| 91久久国产综合久久 | 羞羞视频在线观免费观看 | 日本中文字幕一区 | 国产区在线 | 国产精品一区二区视频 | 超碰在线播 | 欧美日韩一区二区三区在线观看 | av一区二区三区四区 | 精品九九久久 | 国产视频久久 | 亚洲高清在线观看 | 日韩在线欧美 | 亚洲国产高清在线 | 成人区一区二区三区 | 精品一区二区久久 | 久久久91精品国产一区二区三区 | 啪啪网站免费 | 91精品国产91久久久久久最新 | 中国妞xxx| 欧美黄色网| 草草视频在线观看 | 久久精品欧美一区二区三区不卡 | 久久久国产一区二区三区 | 99爱视频| 成人午夜免费视频 | 欧美 | 久久久久久亚洲一区二区三区蜜臀 | 久久久美女 | 久久综合入口 | 黄网站色大毛片 |