国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

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

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

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

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

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

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

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

業務中,會遇到這樣的問題,就是感覺返回的主鍵,插入作為其他表的外鍵。

那么問題來了,如何去實現,其實方法比較簡單,這里就是重點記錄下,會出現的誤區。

用自動生成sql工具的話,加上下面這句話

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

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

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

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

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

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

而是在參數里面取。

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 91香蕉国产线在线观看免费 | 亚洲品质自拍视频网站 | 92av在线 | 天堂在线www网亚洲 天堂在线视频网站 | 久草视频国产 | 九草在线免费观看 | 欧美日韩在线视频一区 | 中文字幕在线视频网 | 欧美高清性色生活片免费观看 | 六月成人网| 精品一区二区三区在线观看 | 久久久久久综合对白国产 | 91精品一区二区三区在线观看 | 女在床上被男的插爽叫视频 | 久久久精品2018免费观看 | 视频精品一区二区 | 国产三级精品三级国产 | 亚洲rct中文字幕在线 | 日韩欧美在线观看视频一区二区 | 宫女淫春 | 久久久久久久99久久久毒国产 | 久草在线青青草 | 国产一区二区三区免费看 | 日韩在线观看视频网站 | 黄色毛片视频校园交易 | 日本亚州视频在线八a | 欧美超高清xoxoxoxo | 亚洲精品国产三级在线观看 | 欧美亚洲国产精品 | 中文字幕在线视频在线看 | 加勒比heyzo| 国产精品久久久久久久久久98 | 三级韩国一区久久二区综合 | 国产九九视频在线观看 | 99精品视频99 | 亚洲专区一 | 亚洲免费成人在线 | 九九99香蕉在线视频网站 | 欧美一级片在线观看 | 久艹视频在线观看 | 国产理论最新国产精品视频 |