日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:45日期:2023-10-19 15:21:06

我們都知道Mybatis在插入單條數(shù)據(jù)的時候有兩種方式返回自增主鍵:

1、對于支持生成自增主鍵的數(shù)據(jù)庫:增加 useGenerateKeys和keyProperty ,<insert>標(biāo)簽屬性。

2、不支持生成自增主鍵的數(shù)據(jù)庫:使用<selectKey>。

但是怎么對批量插入數(shù)據(jù)返回自增主鍵的解決方式網(wǎng)上看到的還是比較少,至少百度的結(jié)果比較少。

Mybatis官網(wǎng)資料提供如下:

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:

<insert useGeneratedKeys='true' keyProperty='id'> insert into Author (username,password,email,bio) values (#{username},#{password},#{email},#{bio})</insert> 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.

<insert 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> 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>

從官網(wǎng)資料可以看出Mybatis是支持批量插入時返回自增主鍵的。

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

解決辦法:

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

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

3、Mapper.xml中使用list變量(parameterType='java.util.List')接受Dao中的參數(shù)集合。

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

mapper.xml層代碼

<!-- 批量新增 --> <insert 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實現(xiàn)層代碼

public List<ShopResource> batchinsertCallId(List<ShopResource> shopResourceList) { this.getSqlSession().insert(getStatement(SQL_BATCH_INSERT_CALL_ID), shopResourceList); return shopResourceList;// 重點介紹 }

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

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

Mapper代碼:

<insert 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層:

當(dāng)設(shè)置了useGeneratedKeys='true' keyProperty='id'后,它會在你插入數(shù)據(jù)庫的同時,將這個對象的id值改為最新的那個id,然后我們只需要取出他就可以了

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

最終效果:

數(shù)據(jù)庫

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

輸出

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

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国内精品美女在线观看| 国产精品久久久免费| 欧美日韩1区2区3区| 中文字幕av一区二区三区人 | 久久香蕉网站| 欧美激情日韩| 欧美好骚综合网| 国产精品成人一区二区不卡| 日本91福利区| 久久av导航| 成人啊v在线| aⅴ色国产欧美| 久久午夜精品| 日韩av在线免费观看不卡| 久久精品xxxxx| 高清一区二区三区av| 99成人超碰| 日韩中文字幕无砖| 精品视频99| 99在线精品视频在线观看| 欧美日本三区| 欧美sm一区| 综合亚洲自拍| 麻豆91在线播放| 四虎影视精品| 伊人精品久久| 电影天堂国产精品| 日本一区二区三区视频在线看| 国产精品va| 亚洲视频www| 国产精品高清一区二区| 91精品一区二区三区综合| 伊人国产精品| 蜜臀久久精品| 国产日本精品| 婷婷激情图片久久| 美女视频黄久久| 亚洲精品在线国产| 正在播放日韩精品| 日韩国产欧美三级| 午夜精品婷婷| 91亚洲国产高清| 欧美一区二区三区久久| 欧美精品自拍| 国产精品精品| 国产精品a久久久久| 蜜臀av亚洲一区中文字幕| 亚洲深夜视频| 精品久久在线| 国产精品一级在线观看| 亚洲久久在线| 免费久久99精品国产| 极品日韩av| 韩日一区二区| 国产精品综合| 国产亚洲字幕| 国产精品亚洲人成在99www| 日韩精品欧美大片| 日本a口亚洲| 国产欧美欧美| 欧美日一区二区在线观看| 中文无码久久精品| 91久久国产| 亚洲一区二区成人| 欧美日韩激情| 精品中文字幕一区二区三区av| 精品国产精品久久一区免费式| 国产精品**亚洲精品| 蜜桃av一区二区在线观看| 女人av一区| 亚洲综合丁香| 综合国产视频| 欧美午夜网站| 久久精品二区亚洲w码| 九九久久国产| 日韩精品专区| 久久中文字幕av| 欧美91视频| 美女精品在线观看| 日本亚洲不卡| 久久精品xxxxx| 精品免费av一区二区三区| 成人av三级| 日韩成人亚洲| japanese国产精品| 视频一区免费在线观看| 日韩精品视频网站| 久久久久久久久成人| av中文字幕在线观看第一页| 亚洲成a人片| 香蕉精品视频在线观看| 亚洲视频二区| 欧美日韩伊人| 狂野欧美性猛交xxxx| 国语精品一区| 亚洲欧美日韩在线观看a三区| 日韩欧美2区| 精品久久久网| 欧美不卡高清| 亚洲v天堂v手机在线| 成人台湾亚洲精品一区二区| 五月婷婷亚洲| 久久在线91| 日韩精品中文字幕一区二区| 国产传媒av在线| 欧美一级久久| 视频福利一区| 欧美国产亚洲精品| 一区二区三区午夜视频| 欧美成a人免费观看久久| 日韩在线电影| 欧美在线亚洲综合一区| 国产不卡精品在线| 日韩欧美激情| 一区二区自拍| 国产超碰精品| 麻豆久久一区二区| 夜久久久久久| 欧美精品一区二区久久| 久久99久久人婷婷精品综合| 中文无码久久精品| 午夜久久美女| 99热精品久久| 日韩精品第一区| 精品理论电影在线| 欧美日韩亚洲三区| 日韩国产精品久久久久久亚洲| 亚洲福利一区| 99视频精品全国免费| 欧美在线不卡| 日韩成人精品一区二区三区| 亚洲一级淫片| 欧美亚洲tv| 国产精品久久久久久久免费软件| 亚洲精品婷婷| 日韩av午夜在线观看| 视频一区中文字幕精品| 亚洲精品黄色| 欧美日一区二区三区在线观看国产免| 美美哒免费高清在线观看视频一区二区 | 夜夜嗨av一区二区三区网站四季av| 欧美极品一区二区三区| 欧美一级网站| 日本不卡高清视频| 欧美国产专区| 精品国产免费人成网站| 久久久男人天堂| av资源亚洲| 亚洲一级网站| 视频在线观看91| 国产日韩欧美三区| 黑森林国产精品av| 五月天久久777| 久久国际精品| 国产精品1区在线| 日韩高清不卡| 亚洲深深色噜噜狠狠爱网站 | 国产精品国产三级国产在线观看| 麻豆精品视频在线| 日韩在线短视频| 免费日韩精品中文字幕视频在线| 亚洲激情中文| 日本在线不卡视频| 国产va免费精品观看精品视频| 久久久久久久久99精品大| 麻豆久久精品| 国产一区二区久久久久| 91精品蜜臀一区二区三区在线| 亚洲最大av| 日韩国产激情| 婷婷成人av| 亚洲欧洲一区二区天堂久久| 国产亚洲字幕| 国产精品美女久久久| 麻豆91精品91久久久的内涵| 亚洲欧美日韩国产一区二区| 国产96在线亚洲| 国产日韩一区| 人人爽香蕉精品| 中文在线а√在线8| 亚洲tv在线| 欧美精品激情| 加勒比视频一区| 天堂俺去俺来也www久久婷婷| 精品捆绑调教一区二区三区| 91国内精品| 在线亚洲激情| 激情五月综合| 久久久精品午夜少妇| 国产精品亚洲综合久久| 免费成人性网站| 在线综合亚洲| 99久久精品费精品国产| 欧美激情 亚洲a∨综合| 日韩精品亚洲专区| 女人天堂亚洲aⅴ在线观看| 韩国精品主播一区二区在线观看 | 激情综合网五月| 亚洲电影有码| 久久婷婷激情|