Mybatis返回插入的主鍵問題解決方案
MyBatis添加記錄后獲取主鍵ID,這是一個很常見的需求。這個需求有分為兩種情況:(1)添加單條記錄時獲取主鍵值;(2)獲取批量添加記錄時各記錄的主鍵值。
備注:MyBatis從3.3.1版本開始支持批量添加記錄并返回各記錄主鍵字段值。
1、添加單一記錄時返回主鍵ID(方法一)
此種方法主要思路是:使用<insert>標(biāo)簽或者@Insert注解的屬性:useGeneratedKeys、keyProperty、keyColumn。下面分別以xml映射器和注解映射器分別詳細(xì)闡述一下。
2、添加單一記錄時返回主鍵ID(方法二)
在上面方法一中,如何獲取自增的id呢,估計很多人還有點疑惑,其實原理很簡單:當(dāng)插入數(shù)據(jù)之后,mybatis再次查詢mysql數(shù)據(jù)庫,獲得了注解id,然后填充到person對象的id屬性的。
業(yè)務(wù)中,會遇到這樣的問題,就是感覺返回的主鍵,插入作為其他表的外鍵。
那么問題來了,如何去實現(xiàn),其實方法比較簡單,這里就是重點記錄下,會出現(xiàn)的誤區(qū)。
用自動生成sql工具的話,加上下面這句話
<generatedKey column="id" sqlStatement="JDBC" identity="true" />
生成的sql文件就會帶 useGeneratedKeys="true" keyProperty="travelId" 屬性。
首先,sql文件里面的需要加上兩個屬性。
<insert id="insertSelective" parameterType="com.sun.dto.HTRAVEL" useGeneratedKeys="true" keyProperty="travelId" ></insert>
- useGeneratedKeys="true" 表示給主鍵設(shè)置自增長
- keyProperty="userId" 表示將自增長后的Id賦值給實體類中的userId字段。
- parameterType="com.chenzhou.mybatis.User" 這個屬性指向傳遞的參數(shù)實體類
然后接收的地方:
注意了,這里主鍵Id是不會在,返回值里面的。
而是在參數(shù)里面取。
int insertSelective(HTRAVEL record);
//這里才是本次插入的主鍵Id
record.getId();
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java 發(fā)送http請求(get、post)的示例
這篇文章主要介紹了Java 發(fā)送http請求的示例,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-10-10
手把手教你設(shè)置IntelliJ IDEA 的彩色代碼主題的圖文教程
本文給出一系列 IntelliJ IDEA 代碼的彩色主題,感興趣的朋友一起看看吧2018-01-01
使用JavaBean根據(jù)指定條件設(shè)置屬性值默認(rèn)值方式
這篇文章主要介紹了使用JavaBean根據(jù)指定條件設(shè)置屬性值默認(rèn)值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
Java實戰(zhàn)之酒店人事管理系統(tǒng)的實現(xiàn)
這篇文章主要介紹了如何用Java實現(xiàn)酒店人事管理系統(tǒng),文中采用的技術(shù)有:JSP、Spring、SpringMVC、MyBatis等,感興趣的小伙伴可以學(xué)習(xí)一下2022-03-03

