午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

Mybatis返回插入的主鍵問題解決方案

瀏覽:15日期:2023-10-22 15:59:39

MyBatis添加記錄后獲取主鍵ID,這是一個(gè)很常見的需求。這個(gè)需求有分為兩種情況:(1)添加單條記錄時(shí)獲取主鍵值;(2)獲取批量添加記錄時(shí)各記錄的主鍵值。

備注:MyBatis從3.3.1版本開始支持批量添加記錄并返回各記錄主鍵字段值。

1、添加單一記錄時(shí)返回主鍵ID(方法一)

此種方法主要思路是:使用<insert>標(biāo)簽或者@Insert注解的屬性:useGeneratedKeys、keyProperty、keyColumn。下面分別以xml映射器和注解映射器分別詳細(xì)闡述一下。

2、添加單一記錄時(shí)返回主鍵ID(方法二)

在上面方法一中,如何獲取自增的id呢,估計(jì)很多人還有點(diǎn)疑惑,其實(shí)原理很簡單:當(dāng)插入數(shù)據(jù)之后,mybatis再次查詢mysql數(shù)據(jù)庫,獲得了注解id,然后填充到person對(duì)象的id屬性的。

業(yè)務(wù)中,會(huì)遇到這樣的問題,就是感覺返回的主鍵,插入作為其他表的外鍵。

那么問題來了,如何去實(shí)現(xiàn),其實(shí)方法比較簡單,這里就是重點(diǎn)記錄下,會(huì)出現(xiàn)的誤區(qū)。

用自動(dòng)生成sql工具的話,加上下面這句話

<generatedKey column='id' sqlStatement='JDBC' identity='true' />

生成的sql文件就會(huì)帶 useGeneratedKeys='true' keyProperty='travelId' 屬性。

首先,sql文件里面的需要加上兩個(gè)屬性。

<insert parameterType='com.sun.dto.HTRAVEL' useGeneratedKeys='true' keyProperty='travelId' ></insert>

useGeneratedKeys='true' 表示給主鍵設(shè)置自增長 keyProperty='userId' 表示將自增長后的Id賦值給實(shí)體類中的userId字段。 parameterType='com.chenzhou.mybatis.User' 這個(gè)屬性指向傳遞的參數(shù)實(shí)體類

然后接收的地方:注意了,這里主鍵Id是不會(huì)在,返回值里面的。

而是在參數(shù)里面取。

int insertSelective(HTRAVEL record);//這里才是本次插入的主鍵Idrecord.getId();

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 中文字幕亚洲一区 | 青青草原av | 欧美日韩精品在线视频 | 成年人网站在线观看视频 | 欧美一级视频在线观看 | 在线免费观看一级片 | 国产麻豆一级片 | 久久精品一级片 | 黄色av免费看 | 色人人| 中文字幕一区二区在线视频 | 日韩成人在线播放 | 综合天堂 | 夜夜操天天 | 欧美精品网 | 337p粉嫩大胆色噜噜噜 | 影音先锋成人在线 | 久久精品国产99国产 | 亚色中文 | 青青艹av| 日韩中文在线视频 | 一级特黄aa大片 | 国产情侣91 | 国内精品久久久久久 | 成年人免费小视频 | 精品久久久在线观看 | 欧美国产日韩在线观看成人 | 免费看污污视频 | 国产激情福利 | 成人黄色三级视频 | 色先锋影音先锋 | 亚洲欧美国产精品专区久久 | 亚洲欧美日韩色 | 黄色片亚洲 | 成年人毛片 | 一级黄色大全 | 亚洲天堂导航 | 99国产精品99久久久久久粉嫩 | 一区二区三区在线观看免费 | 97国产精品 | 一级肉体全黄裸片 |