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

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

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

服務器之家 - 編程語言 - Java教程 - Mybatis批量插入返回插入成功后的主鍵id操作

Mybatis批量插入返回插入成功后的主鍵id操作

2021-08-31 10:49蔣老濕 Java教程

這篇文章主要介紹了Mybatis批量插入返回插入成功后的主鍵id操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

我們都知道mybatis在插入單條數據的時候有兩種方式返回自增主鍵:

1、對于支持生成自增主鍵的數據庫:增加 usegeneratekeys和keyproperty ,<insert>標簽屬性。

2、不支持生成自增主鍵的數據庫:使用<selectkey>。

但是怎么對批量插入數據返回自增主鍵的解決方式網上看到的還是比較少,至少百度的結果比較少。

mybatis官網資料提供如下:

first, if your database supports auto-generated key fields (e.g. mysql and sql server), then you can simply set usegeneratedkeys="true" and set the keyproperty to the target property and you're done. for example, if the authortable above had used an auto-generated column type for the id, the statement would be modified as follows:

?
1
2
3
4
5
6
7
8
9
10
11
12
<insert id="insertauthor" usegeneratedkeys="true"
 keyproperty="id">
 insert into author (username,password,email,bio)
 values (#{username},#{password},#{email},#{bio})
</insert>
 
 
 id="insertauthor" usegeneratedkeys="true"
 keyproperty="id">
 insert into author (username,password,email,bio)
 values (#{username},#{password},#{email},#{bio})
</insert>

if your database also supports multi-row insert, you can pass a list or an array of authors and retrieve the auto-generated keys.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<insert id="insertauthor" usegeneratedkeys="true"
 keyproperty="id">
 insert into author (username, password, email, bio) values
 <foreach item="item" collection="list" separator=",">
 (#{item.username}, #{item.password}, #{item.email}, #{item.bio})
 </foreach>
</insert>
 
 
 id="insertauthor" usegeneratedkeys="true"
 keyproperty="id">
 insert into author (username, password, email, bio) values
 <foreach item="item" collection="list" separator=",">
 (#{item.username}, #{item.password}, #{item.email}, #{item.bio})
 </foreach>
</insert>

從官網資料可以看出mybatis是支持批量插入時返回自增主鍵的。

但是在本地測試的時候使用上述方式確實不能返回自增id,而且還報錯(不認識keyproperty中指定的id屬性),然后在網上找相關資料。終于在stackoverflow上面找到了一些信息。

解決辦法:

1、升級mybatis版本到3.3.1。官方在這個版本中加入了批量新增返回主鍵id的功能

2、在dao中不能使用@param注解。

3、mapper.xml中使用list變量(parametertype="java.util.list")接受dao中的參數集合。

下面是具體代碼過程,可供參考

mapper.xml層代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
<!-- 批量新增 -->
 <insert id="batchinsert" parametertype="java.util.list" usegeneratedkeys="true" keyproperty="id" >
 insert into
 <include refid="t_shop_resource" />
 (relation_id, summary_id, relation_type)
 values
 <foreach collection="list" index="index" item="shopresource" separator=",">
 (
  #{shopresource.relationid}, #{shopresource.summaryid}, #{shopresource.relationtype}
 )
 </foreach>
 </insert>

dao實現層代碼

?
1
2
3
4
5
public list<shopresource> batchinsertcallid(list<shopresource> shopresourcelist)
 {
 this.getsqlsession().insert(getstatement(sql_batch_insert_call_id), shopresourcelist);
 return shopresourcelist;// 重點介紹
 }

補充:mybatis 插入的同時獲取主鍵id

有時候進行一些多步操作的時候就需要得到最新插入一條記錄的id號,那么如何在插入的同時返回id號

mapper代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
<insert id="insertfeeds" parametertype="com.yj.pojo.feeds" usegeneratedkeys="true" keyproperty="id">
 insert into feeds (id, title, content,
 pic, video, auther_id,
 comments, favours, likes,
 cover_select, views, set_time,
 kind)
 values (#{id,jdbctype=integer}, #{title,jdbctype=varchar}, #{content,jdbctype=varchar},
 #{pic,jdbctype=varchar}, #{video,jdbctype=varchar}, #{autherid,jdbctype=varchar},
 #{comments,jdbctype=integer}, #{favours,jdbctype=integer}, #{likes,jdbctype=integer},
 #{coverselect,jdbctype=integer}, #{views,jdbctype=integer}, #{settime,jdbctype=varchar},
 #{kind,jdbctype=varchar})
 </insert>

service層:

當設置了usegeneratedkeys="true" keyproperty="id"后,它會在你插入數據庫的同時,將這個對象的id值改為最新的那個id,然后我們只需要取出他就可以了

Mybatis批量插入返回插入成功后的主鍵id操作

最終效果:

數據庫

Mybatis批量插入返回插入成功后的主鍵id操作

輸出

Mybatis批量插入返回插入成功后的主鍵id操作

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。如有錯誤或未考慮完全的地方,望不吝賜教。

原文鏈接:https://blog.csdn.net/jiangeeq/article/details/55047116

延伸 · 閱讀

精彩推薦
  • Java教程Java8中Stream使用的一個注意事項

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

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

    阿杜7472021-02-04
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

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

    大行者10067412021-08-30
  • Java教程20個非常實用的Java程序代碼片段

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

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

    lijiao5352020-04-06
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

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

    Java教程網2942020-09-17
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

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

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

    spcoder14552021-10-18
  • Java教程小米推送Java代碼

    小米推送Java代碼

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

    富貴穩中求8032021-07-12
  • Java教程升級IDEA后Lombok不能使用的解決方法

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

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

    程序猿DD9332021-10-08
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

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

    littleschemer13532021-05-16
主站蜘蛛池模板: 国产精品一区二区国产 | 午夜在线观看视频 | 国产精品成人扳一级aa毛片 | 春光乍泄在线 | 国产一二区视频 | 亚洲国产欧美另类va在线观看 | 亚洲第一福利视频 | 亚洲一区二区成人 | 欧美日韩国产成人综合在线影院 | 继的朋友无遮漫画免费观看73 | 黄动漫车车好快的车车a | 午夜dj影院在线视频观看完整 | 欧美激情影音先锋 | 桃花岛在线 | 富士av105 | 欧美四区 | 日韩欧美在线观看综合网另类 | 亚洲精品午夜在线观看 | 免费看男女污污完整版 | 国产日韩欧美不卡www | 日本免费在线播放 | 天美传媒在线视频 | 千金肉奴隶免费观看 | 湿好紧太硬了我太爽了 | 美女和男人免费网站视频 | 久99久热只有精品国产99 | 免费看一级大片 | 息与子中文字幕完整在线 | 国产肥女bbwbbw | 欧美国产日本高清不卡 | 国产麻豆麻豆 | 毛片视频网站 | 国内精品一区二区三区东京 | 亚洲男男video | 亚洲视频第一页 | 国产videos hd | 无人影院免费观看 | 好姑娘完整版在线观看中文 | 91国语自产拍在线观看 | 日本网| www.爱情岛论坛 |