亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

前提條件

假設我們這里有一個 Student 表,結構如下

sidnameage
101Jone18
102Jack20
103Tom28

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

問題提出

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

StudentDao 接口中的 insert 方法

boolean insertStudent(Student student);

StudentDao.xml 中的 insert 標簽

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

單元測試類中的方法

@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í)行后的結果

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

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

解決方法

方法一

修改 StudentDao.xml 中的 insert 標簽,配置 useGeneratedKeys 和 keyProperty

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

說明:

1、useGeneratedKeys=“true” 表示給主鍵設置自增長。

2、keyProperty=“sid” 表示將自增長后的 Id 賦值給實體類中的 sid 字段。

運行結果:成功返回了主鍵 sid

方法二(推薦)

修改 StudentDao.xml 中的 insert 標簽,在 insert 標簽中編寫 selectKey 標簽

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

說明:

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

運行結果:成功返回了主鍵 sid

方法三

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

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

同樣是修改 StudentDao.xml 中的 insert 標簽,在 insert 標簽中編寫 selectKey 標簽

<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 并未設置 unique,所以不在這里進行測試,有興趣可以自行測試。

補充知識點:

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標簽:將插入到數(shù)據(jù)庫的某條記錄的主鍵,返回到指定對象(user)對應屬性中。
keyProperty:  指定返回的主鍵,存儲在對象中(user)的哪個屬性
order:相對于insert語句,selectKey標簽中的sql的執(zhí)行順序。由于mysql的自增原理,執(zhí)行完insert語句之后才將主鍵生成,所以這里selectKey的執(zhí)行順序為after。
resultType:  返回的主鍵對應的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>

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

相關文章

  • Java8時間轉換(LocalDateTime)代碼實例

    Java8時間轉換(LocalDateTime)代碼實例

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

    List集合對象中按照不同屬性大小排序的實例

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

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

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

    詳解MyBatis?ResultSetHandler?結果集的解析過程

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

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

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

    Spring EL表示式的運用@Value說明

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

    springBoot詳解集成Swagger流程

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

    ConcurrentHashMap?存儲結構源碼解析

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

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

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

    學習Java之異常到底該如何捕獲和處理

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

最新評論