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

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

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
主站蜘蛛池模板: 国产精品爱久久久久久久 | 国产精品69毛片高清亚洲 | 亚洲精品美女 | 欧美一级二级三级视频 | 国产羞羞视频在线观看 | 国产精品视频一区二区三区不卡 | 日韩毛片在线观看 | 日韩免费av一区二区 | 一级毛片免费看 | 成人日韩在线 | 亚洲网站视频 | 国产精品视屏 | 国产免费视频在线 | 亚洲视频一区 | 操操操影院 | 国产精品成人观看视频国产奇米 | 免费观看视频毛片 | 免费观看aaa | 日韩成人 | 亚洲视频在线观看 | 亚洲天堂网站 | 久久精品一区二区三区中文字幕 | 久久国产免费 | 黄视频日本 | 色xx综合网| 日韩国产欧美一区 | 国产日韩精品一区 | 国产精品香蕉在线观看 | 国产成人精品一区二区三区 | 国产欧美精品 | 视频精品一区二区 | 国产精品永久免费自在线观看 | 欧美在线观看免费观看视频 | 亚洲午夜精品 | 欧美日韩高清在线一区 | 91性高湖久久久久久久久网站 | 久久亚洲一区 | 国产高清美女一级a毛片久久 | 久久首页| 国产精品一级大片 | 一级毛片一级毛片一级毛片 |