国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

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
主站蜘蛛池模板: 国产福利91精品一区二区 | 日韩中文字幕在线视频 | 一级中文字幕 | 香蕉久久一区二区不卡无毒影院 | 国产精品亲子伦av一区二区三区 | 中文字幕日韩在线 | 91亚洲国产 | 夜久久 | 久久免| 狠狠狠狠狠狠干 | 国产91在线观看 | 成人在线一区二区三区 | 老熟妇午夜毛片一区二区三区 | 一区二区日本 | 精品一区二区av | 亚洲国产成人av好男人在线观看 | 国产精品成人一区二区三区夜夜夜 | 久久久久久久久99精品 | 韩日一区二区三区 | 国产精品视频久久久 | 久久久一级 | 国产亚洲精品久久久久久久久 | 黄色在线免费看 | 亚洲欧美在线精品 | 欧美日韩一区二区三区不卡视频 | 老丁头电影在线观看 | 日韩国伦理久久一区 | 国产精品精品视频一区二区三区 | 亚洲一区中文字幕在线 | www.久久精品 | 青青久草 | 99r在线 | 黄色在线免费观看 | 亚洲美女二区 | 激情欧美一区二区三区中文字幕 | 中文在线视频 | 国产传媒视频 | 亚洲综合中文网 | 视频在线一区 | 欧美一级特黄在线观看 | 精品一二三区 |