首頁 > 軟體

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

2020-09-22 15:00:50

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 id="insertSelective" 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);
//這裡才是本次插入的主鍵Id
record.getId();

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com