Mybatis返回插入的主鍵問題解決方案
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對象的id屬性的。
業(yè)務(wù)中,會遇到這樣的問題,就是感覺返回的主鍵,插入作為其他表的外鍵。
那么問題來了,如何去實(shí)現(xiàn),其實(shí)方法比較簡單,這里就是重點(diǎn)記錄下,會出現(xiàn)的誤區(qū)。
用自動生成sql工具的話,加上下面這句話
<generatedKey column='id' sqlStatement='JDBC' identity='true' />
生成的sql文件就會帶 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是不會在,返回值里面的。
而是在參數(shù)里面取。
int insertSelective(HTRAVEL record);//這里才是本次插入的主鍵Idrecord.getId();
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. DBeaver連接MySQL的超詳細(xì)步驟2. MySQL基本調(diào)度策略淺析3. Oracle數(shù)據(jù)庫9i和10g環(huán)境下使用*.ora4. golang實(shí)現(xiàn)mysql數(shù)據(jù)庫事務(wù)的提交與回滾5. 解析MySQL binlog6. Oracle 數(shù)據(jù)字典7. 學(xué)習(xí)SQL SERVER的存儲過程-之一認(rèn)識存儲過程語法8. 關(guān)于MySQL中explain工具的使用9. mybatis-plus如何使用sql的date_format()函數(shù)查詢數(shù)據(jù)10. 高并發(fā)狀態(tài)下Replace Into造成的死鎖問題解決
