溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyBatis如何插入數(shù)據(jù)返回主鍵

發(fā)布時間:2021-08-05 15:12:48 來源:億速云 閱讀:156 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關(guān)MyBatis如何插入數(shù)據(jù)返回主鍵的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

Service層:

public int addUser(UserDomian user){
  int i = userMapper.insert(user);
}

xml:

<insert id="insert" parameterType="....UserDomain">
  insert into t_user(user_name,password)
  values
  (#{userName},#{password})
</insert>

這樣userMapper的insert方法成功插入之后返回值為影響行數(shù),也就是1。而且插入之后userDomain實體類的userId為null。

我們都知道在MyBatis中,xml的insert語句中將useGeneratedKeys指定為true,那么返回之后就會得到新增的主鍵值,具體寫法如下:

<insert id="insert" parameterType="....UserDomain" useGeneratedKeys="true" keyProperty="userId">
  insert into t_user(user_name,password)values(#{userName},#{password})
</insert>

前提條件是對應的mysql表中id必須是自增的,并且對應的UserDomain實體類中有g(shù)et、set方法,而且只適用于與mySql數(shù)據(jù)庫,Oracle數(shù)據(jù)庫不支持。

但是這樣設(shè)置之后,在service層打斷點,插入成功之后UserDomain確實和之前不一樣,他的userId不再是null了,而是具體的主鍵id值,但是usetMapper的insert方法的返回值依然是1,也就是插入的影響行數(shù)。

也就是說,這樣設(shè)置,mapper接口返回值依然是成功插入的記錄數(shù),但不同的是主鍵值已經(jīng)賦值到領(lǐng)域模型實體的id中了。

感謝各位的閱讀!關(guān)于“MyBatis如何插入數(shù)據(jù)返回主鍵”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI