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

Mybatis?在?insert?插入操作后返回主鍵?id的操作方法

 更新時(shí)間:2022年12月15日 11:47:26   作者:Aries66666  
這篇文章主要介紹了Mybatis?在?insert?插入操作后返回主鍵?id的操作方法,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

Mybatis 在 insert 插入操作后返回主鍵 id

前提條件

假設(shè)我們這里有一個(gè) Student 表,結(jié)構(gòu)如下

sidnameage
101Jone18
102Jack20
103Tom28

其中主鍵 sid 是自增的,那么我們插入數(shù)據(jù)時(shí)就不用插入 sid,它會(huì)生成一個(gè)自增的 sid。

問題提出

這里有一個(gè)問題,我們執(zhí)行插入語句之后,并不能獲取到生成的 sid。

StudentDao 接口中的 insert 方法

boolean insertStudent(Student student);

StudentDao.xml 中的 insert 標(biāo)簽

<insert id="insertStudent" parameterType="Student">
    insert into student(name, age)
    VALUES (#{name} , #{age})
</insert>

單元測(cè)試類中的方法

@Test
public void insertUser() {
    Student student = new Student(0,"xxx", 28);

    boolean flag = studentDao.insertStudent(student);
    System.out.println(flag);
    System.out.println(student);
}

執(zhí)行后的結(jié)果

這里并不能獲取到生成的 sid,如果要獲取這個(gè) sid,還要根據(jù) name 來查詢數(shù)據(jù)庫,而且 name 也需要是 unique 唯一性的。

那么,有沒有辦法讓我們能夠執(zhí)行插入語句后,直接獲取到生成的 sid 呢,當(dāng)然是有的。

解決方法

方法一

修改 StudentDao.xml 中的 insert 標(biāo)簽,配置 useGeneratedKeys 和 keyProperty

<insert id="insertStudent" parameterType="Student" useGeneratedKeys="true" keyProperty="sid">
    insert into student(name, age)
    VALUES (#{name} , #{age})
</insert>

說明:

1、useGeneratedKeys=“true” 表示給主鍵設(shè)置自增長(zhǎng)。

2、keyProperty=“sid” 表示將自增長(zhǎng)后的 Id 賦值給實(shí)體類中的 sid 字段。

運(yùn)行結(jié)果:成功返回了主鍵 sid

方法二(推薦)

修改 StudentDao.xml 中的 insert 標(biāo)簽,在 insert 標(biāo)簽中編寫 selectKey 標(biāo)簽

<insert id="insertStudent" parameterType="Student" useGeneratedKeys="true" keyProperty="sid">
    insert into student(name, age)
    VALUES (#{name} , #{age})
</insert>

說明:

1、< insert> 標(biāo)簽中沒有 resultType 屬性,但是 < selectKey> 標(biāo)簽是有的。
2、order=“AFTER” 表示先執(zhí)行插入語句,之后再執(zhí)行查詢語句。
3、keyProperty=“sid” 表示將自增長(zhǎng)后的 Id 賦值給實(shí)體類中的 sid 字段。
4、SELECT LAST_INSERT_ID() 表示 MySQL 語法中查詢出剛剛插入的記錄自增長(zhǎng) Id。

運(yùn)行結(jié)果:成功返回了主鍵 sid

方法三

這種方法需要在一定條件下才能使用,就是 name 需要是 unique,不可重復(fù)的。

這樣才能在插入后,根據(jù) name 來查詢出主鍵 sid。

同樣是修改 StudentDao.xml 中的 insert 標(biāo)簽,在 insert 標(biāo)簽中編寫 selectKey 標(biāo)簽

<insert id="insertStudent" parameterType="Student">
    insert into student(name, age)
    VALUES (#{name} , #{age})

    <selectKey keyProperty="sid" order="AFTER" resultType="int">
        select sid from student where name = #{name}
    </selectKey>
</insert>

原理上面也講了,就是在執(zhí)行插入語句之后,再執(zhí)行查詢語句,將 sid 查出來。

不過我這里 name 并未設(shè)置 unique,所以不在這里進(jìn)行測(cè)試,有興趣可以自行測(cè)試。

補(bǔ)充知識(shí)點(diǎn):

mybatis中Insert語句如何返回插入的主鍵

方法一:

mapper.java

    /**
     * 添加部門
     * @param department
     * @return
     */
    Integer insertDep(Department department);

xml

    <insert id="insertDep" parameterType="com.example.pojo.entity.Department">
        <selectKey keyProperty="departmentId" order="AFTER" resultType="java.lang.Integer ">
            select LAST_INSERT_ID()
        </selectKey>
        insert into sys_department(name,parentId,enabled,isParent)
        VALUES(#{name},#{parentId},1,0)
    </insert>

其中:

selectKey標(biāo)簽:將插入到數(shù)據(jù)庫的某條記錄的主鍵,返回到指定對(duì)象(user)對(duì)應(yīng)屬性中。
keyProperty:  指定返回的主鍵,存儲(chǔ)在對(duì)象中(user)的哪個(gè)屬性
order:相對(duì)于insert語句,selectKey標(biāo)簽中的sql的執(zhí)行順序。由于mysql的自增原理,執(zhí)行完insert語句之后才將主鍵生成,所以這里selectKey的執(zhí)行順序?yàn)閍fter。
resultType:  返回的主鍵對(duì)應(yīng)的JAVA類型
LAST_INSERT_ID():  是mysql的函數(shù),返回auto_increment自增列新記錄id值。

 方法二

使用:

useGeneratedKeys="true" keyProperty="departmentId"
    <insert id="insertDep" parameterType="com.example.pojo.entity.Department" useGeneratedKeys="true" keyProperty="departmentId">
        insert into sys_department(departmentId,name,parentId,enabled,isParent)
        VALUES(uuid(),#{name},#{parentId},1,0)
    </insert>

到此這篇關(guān)于mybatis中Insert語句如何返回插入的主鍵的文章就介紹到這了,更多相關(guān)mybatis Insert返回插入的主鍵內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例

    Java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例

    這篇文章主要介紹了java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • List集合對(duì)象中按照不同屬性大小排序的實(shí)例

    List集合對(duì)象中按照不同屬性大小排序的實(shí)例

    下面小編就為大家?guī)硪黄狶ist集合對(duì)象中按照不同屬性大小排序的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • java.lang.UnsupportedClassVersionError錯(cuò)誤的解決辦法(附圖文)

    java.lang.UnsupportedClassVersionError錯(cuò)誤的解決辦法(附圖文)

    這篇文章主要給大家介紹了關(guān)于java.lang.UnsupportedClassVersionError錯(cuò)誤的解決辦法,"java.lang.UnsupportedClassVersionError"意味著您正在運(yùn)行的Java版本與編譯該類時(shí)使用的Java版本不兼容,需要的朋友可以參考下
    2023-10-10
  • 詳解MyBatis?ResultSetHandler?結(jié)果集的解析過程

    詳解MyBatis?ResultSetHandler?結(jié)果集的解析過程

    這篇文章主要為大家介紹了MyBatis?ResultSetHandler?結(jié)果集的解析過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • java實(shí)現(xiàn)可視化日歷

    java實(shí)現(xiàn)可視化日歷

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)可視化日歷,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • Spring EL表示式的運(yùn)用@Value說明

    Spring EL表示式的運(yùn)用@Value說明

    這篇文章主要介紹了Spring EL表示式的運(yùn)用@Value說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • springBoot詳解集成Swagger流程

    springBoot詳解集成Swagger流程

    Swagger是一個(gè)規(guī)范和完整的框架,用于生成、描述、調(diào)用和可視化?Restful?風(fēng)格的?Web?服務(wù)??傮w目標(biāo)是使客戶端和文件系統(tǒng)作為服務(wù)器以同樣的速度來更新。文件的方法、參數(shù)和模型緊密集成到服務(wù)器端的代碼,允許API來始終保持同步
    2022-06-06
  • ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析

    ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析

    這篇文章主要為大家介紹了ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 使用Jackson實(shí)現(xiàn)Map與Bean互轉(zhuǎn)方式

    使用Jackson實(shí)現(xiàn)Map與Bean互轉(zhuǎn)方式

    這篇文章主要介紹了使用Jackson實(shí)現(xiàn)Map與Bean互轉(zhuǎn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • 學(xué)習(xí)Java之異常到底該如何捕獲和處理

    學(xué)習(xí)Java之異常到底該如何捕獲和處理

    我們知道,Java的異常處理是通過5個(gè)關(guān)鍵字來實(shí)現(xiàn)的,即try、catch、throw、throws和finally,try?catch語句用于捕獲并處理異常,但具體該怎么捕獲異常,怎么拋出異常,什么時(shí)候拋,什么時(shí)候捕,感興趣的小伙伴跟著小編一起來看看吧
    2023-08-08

最新評(píng)論