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

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

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

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

分析問題

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

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

解決方法

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

這樣就可以查詢一次數(shù)據(jù)庫,將所有數(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ā)的語法以及操作

MyBatis批量添加(foreach標簽)

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

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

foreach標簽包含的的常用屬性有collection,item,index,open,separator,close

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

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

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

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

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

使用示例

對于前兩種情況的使用非常簡單易懂,這里我們對第三種情況進行簡單的使用,來進行一個批量插入。

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é)

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

相關(guān)文章

最新評論