亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

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

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

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

主鍵回填 keyProperty:指定哪個字段是主鍵 useGeneratedKeys:這個主鍵是否使用數據庫內置生成策略

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

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

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

使用自定義規則生成主鍵

實際工作上有時候主鍵的生成規則并不是這么簡單,比如我們取消t_user的主鍵自增規則。我們的要求是:

如果t_user表沒有數據,我們也要設置主鍵為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>

這樣我們就可以根據自定義的規則來處理生成主鍵了。

MyBatis中配置主鍵回填

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

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

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

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

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 日本一区二区高清不卡 | 毛片大全网站 | 日本黄色片www| 国产精品一区欧美日韩制服 | 欧美一级做一a做片性视频 欧美一级做一级爱a做片性 | 黄色wwwcom| 亚洲成人播放 | 国产精品日韩欧美亚洲另类 | 丁香六月色婷婷 | 一区二区三区在线免费视频 | 日本高清视频色视频kk266 | 精品福利一区二区三区 | 亚洲综合图片人成综合网 | 免费观看黄色a一级录像 | 中国国产成人精品久久 | 久久精品国产无限资源 | 亚洲精品久 | 亚洲成在人线影视天堂网 | 91午夜精品亚洲一区二区三区 | 南京巨根无套操到你窒息 | 欧美日韩一区二区在线视频 | 亚洲国产国产综合一区首页 | 国产xxxx色视频在线观看14 | 一级黄色毛片 | 成人看片黄a免费看视频 | 美女黄页视频 | 国产日韩欧美一区二区三区在线 | 狠狠亚洲婷婷综合色香五 | 毛片黄色片 | 久久精品一区二区三区日韩 | 2022国产成人福利精品视频 | 日韩精品中文字幕一区三区 | 一级毛片真人免费观看 | 高清成人爽a毛片免费网站 高清成人综合 | 成人在线欧美 | 国产一区二区不卡免费观在线 | 国内自拍videos hd | 亚洲午夜精品 | 中国一级黄色 | 2022国产成人精彩在线视频 | 特级全黄一级毛片免费 |