欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis中的循環(huán)插入insert foreach問(wèn)題

 更新時(shí)間:2023年11月04日 10:24:46   作者:攻城獅Chova  
這篇文章主要介紹了MyBatis中的循環(huán)插入insert foreach問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

MyBatis循環(huán)插入insert foreach

分析問(wèn)題

在后端數(shù)據(jù)需要的循環(huán)插入數(shù)據(jù)庫(kù)中時(shí),不要在實(shí)現(xiàn)類ServiceImpl中使用foreach語(yǔ)句

這樣會(huì)導(dǎo)致每次插入一條數(shù)據(jù)就會(huì)查詢一次數(shù)據(jù)庫(kù),導(dǎo)致性能極低

解決方法

在MyBatis中的Mapper.xml使用insert foreach實(shí)現(xiàn)數(shù)據(jù)的循環(huán)插入

這樣就可以查詢一次數(shù)據(jù)庫(kù),將所有數(shù)據(jù)循環(huán)插入

	<insert id="saveList">
        insert into
        table (
        id ,
        column
        )values
        <foreach collection="list" item="item" index="index" separator="," >
            (
            #{item.id},
            #{item.column}
            )
        </foreach>
    </insert>

心得:

研究MyBatis框架,熟悉相關(guān)便捷開發(fā)的語(yǔ)法以及操作

MyBatis批量添加(foreach標(biāo)簽)

delete from  xxx_table where id  in 
<foreach collection="list" item="item" index="index" open="(" separator="," close=")"> 
		#{item}
</foreach>  => (1,2,3,4)

foreach標(biāo)簽:主要應(yīng)用于批量刪除與批量插入操作。

foreach標(biāo)簽包含的的常用屬性有collection,item,index,open,separator,close

  • collection:表示迭代集合的名稱,自定義名稱,可以使用@Param注解指定
  • 只有一個(gè)List/Array/Map類型參數(shù)時(shí),如果不加@Param注解,collection分別必須填:list、array、map中的key屬性
  • 有多個(gè)參數(shù)時(shí),不加@Param注解,collection和默認(rèn)參數(shù)名稱一致
  • 如果加@Param注解,都和注解定義一致
  • item:表示本次迭代獲取的元素,自定義名稱;表示本次迭代獲取的元素,若collection為L(zhǎng)ist、Set或者數(shù)組,則表示其中的元素;若collection為map,則代表key-value的value,該參數(shù)為必選
  • separator:分隔符,mybatis會(huì)在每次迭代后給sql語(yǔ)句append上separator屬性指定的字符,該參數(shù)為可選項(xiàng)
  • open:表示該語(yǔ)句以什么開始,最常用的是左括弧’(’,注意:mybatis會(huì)將該字符拼接到整體的sql語(yǔ)句之前,并且只拼接一次,該參數(shù)為可選項(xiàng)
  • close:表示該語(yǔ)句以什么開始,最常用的是左括弧’(’,注意:mybatis會(huì)將該字符拼接到整體的sql語(yǔ)句之前,并且只拼接一次,該參數(shù)為可選項(xiàng)
  • index:在list、Set和數(shù)組中,index表示當(dāng)前迭代的位置,在map中,index代指是元素的key,該參數(shù)是可選項(xiàng)。

在使用foreach的時(shí)候最關(guān)鍵的也是最容易出錯(cuò)的就是collection屬性,該屬性是必須指定的,但是在不同情況下,該屬性的值是不一樣的,主要有一下3種情況

1.如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)List的時(shí)候,collection屬性值為list

2.如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)array數(shù)組的時(shí)候,collection的屬性值為array

3.如果傳入的參數(shù)是多個(gè)的時(shí)候,我們就需要把它們封裝成一個(gè)Map了,當(dāng)然單參數(shù)也可以封裝成map,實(shí)際上如果你在傳入?yún)?shù)的時(shí)候,在MyBatis里面也是會(huì)把它封裝成一個(gè)Map的,map的key就是參數(shù)名,所以這個(gè)時(shí)候collection屬性值就是傳入的List或array對(duì)象在自己封裝的map里面的key。

使用示例

對(duì)于前兩種情況的使用非常簡(jiǎn)單易懂,這里我們對(duì)第三種情況進(jìn)行簡(jiǎn)單的使用,來(lái)進(jìn)行一個(gè)批量插入。

controller層

        LocalDateTime localDateTime = LocalDateTime.now();
        teacherCourseList.setCreate_time(localDateTime);
        teacherCourseList.setUpdate_time(localDateTime);
        log.info("入?yún)?======"+teacherCourseList);
 
        Map<String,Object> map=new HashMap<>();
        map.put("username",teacherCourseList.getUsername());
        map.put("CourseList",teacherCourseList.getCourseList());
        map.put("create_time",teacherCourseList.getCreate_time());
        map.put("update_time",teacherCourseList.getUpdate_time());
        courseService.batchInsert(map);

xml

<insert id="batchInsert">
    insert into ref_teacher_course (teacher_id,course_id,create_time,update_time)
    values 
    <foreach collection="teacherCourseList.CourseList" item="item" index="index" separator=",">
        (#{teacherCourseList.username},
        #{item},
        #{teacherCourseList.create_time},
        #{teacherCourseList.update_time})
    </foreach>
</insert>

mapper

void batchInsert(@Param("teacherCourseList") Map map);

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論