一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 詳解mybatis插入數據后返回自增主鍵ID的問題

詳解mybatis插入數據后返回自增主鍵ID的問題

2021-10-24 14:49charlyFeng Java教程

這篇文章主要介紹了mybatis插入數據后返回自增主鍵ID詳解,本文通過場景分析示例代碼相結合給大家介紹的非常詳細,需要的朋友可以參考下

1.場景介紹:

?開發過程中我們經常性的會用到許多的中間表,用于數據之間的對應和關聯.這個時候我們關聯最多的就是ID,我們在一張表中插入數據后級聯增加到關聯表中.我們熟知的mybatis在插入數據后返回的是插入成功的條數,那么這個時候我們想要得到相應的這條新增數據的ID,該怎么辦呢?

2.插入數據返回自增主鍵ID方法(一)

在映射器中配置獲取記錄主鍵值xml映射:

在xml中定義useGeneratedKeys為true,返回主鍵id的值,keyProperty和keyColumn分別代表數據庫記錄主鍵字段和java對象成員屬性名

?
1
2
3
4
<!-- 插入數據:返回記錄主鍵id值 -->
<insert id="insert" useGeneratedKeys="true" keyProperty="id"  keyColumn="id">
        insert  into stu (name,age) values (#{name},#{age})
</insert>

接口映射器

在接口映射器中通過注解@Options分別設置參數useGeneratedKeys,keyProperty,keyColumn值

?
1
2
3
4
// 返回主鍵字段id值
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
@Insert("insert  into stu (name,age) values (#{name},#{age})")
void insert(Student stu);

獲取新添加記錄主鍵字段值

需要注意的是,在MyBatis中添加操作返回的是記錄數并非記錄主鍵id。因此,如果需要獲取新添加記錄的主鍵值,需要在執行添加操作之后,直接讀取Java對象的主鍵屬性。

?
1
2
3
Integer rows = sqlSession.getMapper(StuMapper.class).insertOneTest(student);
System.out.println("rows = " + rows); // 添加操作返回記錄數
System.out.println("id = " + student.getId()); // 執行添加操作之后通過Java對象獲取主鍵屬性值

添加批量記錄時返回主鍵ID

如果希望執行批量添加并返回各記錄主鍵字段值,只能在xml映射器中實現,在接口映射器中無法做到。

?
1
2
3
4
5
6
7
<!-- 批量添加數據,并返回主鍵字段 -->
<insert id="insert" useGeneratedKeys="true" keyProperty="id">
        insert  into stu (name,age) values
        <foreach collection="list" separator="," item="t">
            (#{t.name},#{t.age})
        </foreach>
</insert>

可以看到,執行批量添加并返回記錄主鍵值的xml映射器配置,跟添加單條記錄時是一致的。不同的地方僅僅是使用了foreach元素構建批量添加語句。

到此這篇關于mybatis插入數據后返回自增主鍵ID詳解的文章就介紹到這了,更多相關mybatis插入數據后返回自增主鍵ID詳解內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/charlypage/p/11253610.html

延伸 · 閱讀

精彩推薦
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java8中Stream使用的一個注意事項

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

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7472021-02-04
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
主站蜘蛛池模板: 亚洲AV久久无码精品九九软件 | 久久毛片网站 | 狠狠色伊人亚洲综合网站色 | 女子监狱第二季在线观看免费完整版 | 亚洲va欧美va天堂v国产综合 | 91在线一区二区三区 | ipx-177绝对领域在线观看 | 性欧洲女人18 | 男人狂躁女人下面狂叫图片 | 第一次做m被调教经历 | 国产综合成人久久大片91 | 五月婷婷俺也去开心 | 毛片啪啪视频 | 国产精品猎奇系列在线观看 | 精品亚洲一区二区三区在线播放 | 国产精品自在欧美一区 | 亚洲bt区 | 久久人妻少妇嫩草AV無碼 | 欧美同志gaypronvideos | 久久精品视频免费 | 桃花岛在线 | 摄像头东北对白清晰 | 天天爱综合| 亚洲午夜性春猛交xxxx | 国产资源站 | 欧美亚洲视频在线观看 | 亲爱的客栈第二季免费观看完整版 | 九九精品视频在线观看 | 为什么丈夫插我我却喜欢被打着插 | xx18美女美国 | 国产精品拍拍拍福利在线观看 | 精品欧美一区二区三区在线观看 | 欧美综合国产精品日韩一 | 精品午夜中文字幕熟女人妻在线 | 国产91网站在线观看 | 国产成人在线播放视频 | 美女mm131爽爽爽久久 | 俄罗斯图书馆无打码久久 | 91精品国产一区 | 美女机机对机机的视频(免费) | 99精品国产高清自在线看超 |