欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis?獲取更新(update)記錄的id之<selectKey>用法說明

 更新時間:2022年05月20日 15:04:33   作者:雙斜杠少年  
這篇文章主要介紹了mybatis?獲取更新(update)記錄的id之<selectKey>用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

獲取更新(update)記錄的id之<selectKey>

問題

用mybatis update 記錄,更新過后想要更新記錄的id 怎么辦?

平常我門都是更新數(shù)據(jù),用更新的條件再查詢一次,得到更新的記錄。這樣我門就進行了兩次數(shù)據(jù)庫操作,鏈接了兩次數(shù)據(jù)庫。增加了接口的處理事件,因為鏈接數(shù)據(jù)庫是很耗時的操作。

簡介

其實可以通過 mybatis 的 selectKey 標簽來解決這個問題。

selectKey 這個標簽大家基本上都用過,比如在插入數(shù)據(jù)的時候,返回插入數(shù)據(jù)的紀錄。如:

?<selectKey resultType="int" order="AFTER" keyProperty="id">
? ? ? ? ? ? SELECT LAST_INSERT_ID()
?</selectKey>
insert into ?。。。。此處省略
  • resultType :返回的類型,為簡單類型。
  • order: 在insert into 語句執(zhí)行后執(zhí)行。
  • keyProperty : 語句執(zhí)行結(jié)果的 返回目標屬性

SELECT LAST_INSERT_ID() 為查詢主體。

此處用法用法就是當 insert into 執(zhí)行后 執(zhí)行 selectKey 的內(nèi)容將數(shù)據(jù)庫的最后一個id 查詢出來映射到傳入數(shù)據(jù)對像的ID 屬性。

解決 獲取update 紀錄的id

假設(shè)我門有個 bean 為people

public class People {
private Integer id?
private String name;
private String email;
...
}

現(xiàn)在我門寫一個更新語句,并將更新的紀錄的ID 返回出來。mybatis 語句如下:

通過 People 的name 去更新 People 的email,并獲取被更新紀錄的id。

? ? <update id="updateByUserName" parameterType="com.test.bean.People">
?<selectKey keyProperty='id' resultType='int' order='BEFORE'>
? ? ? ? ? ? SELECT
? ? ? ? ? ? (select id FROM people WHERE
? ? ? ? ? ? ?name = #{name})id
? ? ? ? ? ? from DUAL
? </selectKey>
? ? ? ? UPDATE people SET
? ? ? email=#{email}
? ? ? ? WHERE
? ? ? ?name =#{name}
? </update>

上述代碼就是通過 selectKey 實現(xiàn)了 通過 People 的name 去更新 People 的email,并獲取被更新紀錄的id。

詳解

?<selectKey keyProperty='id' resultType='int' order='BEFORE'>

此處的 keyProperty=’id’ 是指將查詢出來的id 映射到傳入updateByUserName 的people 的id 。類型為int

因為可能查到name 以后可能會修改name 所以order=’BEFORE’ 要在執(zhí)行update之前進行查詢,并把id返回出來。

SELECT
? ? (select id FROM people WHERE
? ? name = #{name})id
from DUAL?

此 SELECT 就是為了獲取 被更新的 people 的id 外邊包裝一個虛表查詢是當 name = #{name} 查詢不到紀錄時不會報空紀錄,會返回 null ,這個就很關(guān)鍵了。

當返回空記錄的時候 mybatis會報錯,說不能轉(zhuǎn)換成 int 型。

當返回null的時候就會轉(zhuǎn)換成int 的 0 。不會報錯,代表沒有查到。(是不是很機智?)

下邊的的更新語句就不說了…

? ?UPDATE people SET
? ? ? email=#{email}
? ? ? ? WHERE
? ? ? ?name =#{name}

<selectKey>標簽的含義

MyBatis 標簽

這個標簽主要用于Insert數(shù)據(jù)時不支持主鍵自動生成的問題

selectKey keyProperty=”m_Id” order=”AFTER” resultType=”int”>
select LAST_INSERT_ID()
selectKey>

SelectKey需要注意order屬性。像Mysql一類支持自動增長類型的數(shù)據(jù)庫中,order需要設(shè)置為after才會取到正確的值。

像Oracle這樣取序列的情況,需要設(shè)置為before,否則會報錯

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MyBatis 使用權(quán)威指南

    MyBatis 使用權(quán)威指南

    MyBatis 是支持定制化 SQL、存儲過程以及高級映射的優(yōu)秀的持久層框架。MyBatis 避免了幾乎所有的 JDBC 代碼和手動設(shè)置參數(shù)以及獲取結(jié)果集,本文給大家介紹MyBatis 使用指南,一起看看吧
    2017-03-03
  • Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發(fā)現(xiàn)了對于集合操作轉(zhuǎn)換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關(guān)于Java8中Stream使用過程中的一個注意事項,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2017-11-11
  • Mybatis多參數(shù)及實體對象傳遞實例講解

    Mybatis多參數(shù)及實體對象傳遞實例講解

    在使用Mybatis的時候,經(jīng)常會有各種各樣的參數(shù)傳遞,不同類型,不同個數(shù)的參數(shù),下面小編通過例子給大家講解下Mybatis多參數(shù)及實體對象傳遞,一起看看吧
    2016-12-12
  • Java注解Annotaton詳解

    Java注解Annotaton詳解

    Java 注解(Annotation)又稱 Java 標注,是 JDK5.0 引入的一種注釋機制,文中給大家介紹了三種基本的Annotaton,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2022-05-05
  • Java SpringBoot啟動指定profile的8種方式詳解

    Java SpringBoot啟動指定profile的8種方式詳解

    這篇文章主要介紹了spring boot 如何指定profile啟動的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java模擬實現(xiàn)QQ三方登錄(單點登錄2.0)

    Java模擬實現(xiàn)QQ三方登錄(單點登錄2.0)

    這篇文章主要為大家詳細介紹了Java模擬實現(xiàn)QQ三方登錄,單點登錄2.0,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • Java中關(guān)于線程安全的三種解決方式

    Java中關(guān)于線程安全的三種解決方式

    這篇文章主要介紹了Java中關(guān)于線程安全的三種解決方式,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 關(guān)于Java中的可見性和有序性問題

    關(guān)于Java中的可見性和有序性問題

    這篇文章主要介紹了關(guān)于Java中的可見性和有序性問題,Java在誕生之初就支持多線程,自然也有針對這三者的技術(shù)方案,今天就學習一下Java如何解決其中的可見性和有序性導致的問題,需要的朋友可以參考下
    2023-08-08
  • Java實現(xiàn)登錄和注冊案例

    Java實現(xiàn)登錄和注冊案例

    這篇文章主要為大家詳細介紹了Java實現(xiàn)登錄和注冊案例,把用戶信息存進集合,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • java上乘武功入門--反射

    java上乘武功入門--反射

    反射是Java的一種機制,一般也叫做反射機制,本文會講反射機制是什么和怎么使用,喜歡的朋友可以觀看一下,希望能給你帶來幫助
    2021-07-07

最新評論