溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Mybatisd對(duì)MySQL批量插入語句的方法是什么

發(fā)布時(shí)間:2021-12-04 13:56:22 來源:億速云 閱讀:140 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容介紹了“Mybatisd對(duì)MySQL批量插入語句的方法是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

1、批量插入

<insert 

        id="insertBatch" 

        parameterType="java.util.List">

        insert into 

            t_student(name, age, class)

        values

        <foreach 

            collection="list" 

            item="item" 

            index="index" 

            separator=",">

            (

                #{item.name,jdbcType=VARCHAR}, 

                #{item.age,jdbcType=INTEGER},

                #{item.class,jdbcType=LONGVARCHAR}

            )

        </foreach>

   </insert>

2、批量更新

方式一:

<update id="updateBatch">

       <foreach 

            collection="list" 

            separator=";" 

            item="stud">

            update t_studetn set

                 name = #{stud.name},

                age = #{stud.age},

                class = #{stud.sex},

            where id = #{stud.id}

       </foreach>

</update>

方式二:

<update 

  id="updateBatch" 

  parameterType="list">

UPDATE t_student

    SET name = CASE id 

<foreach 

collection="list" 

item="i" 

index="index">

        WHEN #{i.id} THEN #{i.name}

</foreach>

    END, 

    age = CASE id 

     <foreach 

collection="list" 

item="i" 

index="index">

        WHEN #{i.id} THEN #{i.age}

</foreach>

    END

WHERE id IN 

<foreach 

collection="list" 

separator="or" 

item="i" 

index="index" >

          id=#{i.id}

    </foreach>

</update>

3、批量刪除

<delete id="deleteBatchByParams">

        delete from 

            t_student

        where 

            id IN

        <foreach 

            collection="ids" 

            item="item" 

            index="index" 

            open="(" close=")" 

            separator=",">

                #{item}

        </foreach>

    </delete>

item循環(huán)體中的具體對(duì)象。支持屬性的點(diǎn)路徑訪問,如item.age,item.info.details。
具體說明:在list和數(shù)組中是其中的對(duì)象,在map中是value。
該參數(shù)為必選。
collection

要做foreach的對(duì)象,作為入?yún)r(shí),List<?>對(duì)象默認(rèn)用list代替作為鍵,數(shù)組對(duì)象有array代替作為鍵,Map對(duì)象沒有默認(rèn)的鍵。
當(dāng)然在作為入?yún)r(shí)可以使用@Param("keyName")來設(shè)置鍵,設(shè)置keyName后,list,array將會(huì)失效。 除了入?yún)⑦@種情況外,還有一種作為參數(shù)對(duì)象的某個(gè)字段的時(shí)候。舉個(gè)例子:
如果User有屬性List ids。入?yún)⑹荱ser對(duì)象,那么這個(gè)collection = "ids"
如果User有屬性Ids ids;其中Ids是個(gè)對(duì)象,Ids有個(gè)屬性List id;入?yún)⑹荱ser對(duì)象,那么collection = "ids.id"
上面只是舉例,具體collection等于什么,就看你想對(duì)那個(gè)元素做循環(huán)。
該參數(shù)為必選。

separator元素之間的分隔符,例如在in()的時(shí)候,separator=","會(huì)自動(dòng)在元素中間用“,“隔開,避免手動(dòng)輸入逗號(hào)導(dǎo)致sql錯(cuò)誤,如in(1,2,)這樣。該參數(shù)可選。
openforeach代碼的開始符號(hào),一般是(和close=")"合用。常用在in(),values()時(shí)。該參數(shù)可選。
closeforeach代碼的關(guān)閉符號(hào),一般是)和open="("合用。常用在in(),values()時(shí)。該參數(shù)可選。
index在list和數(shù)組中,index是元素的序號(hào),在map中,index是元素的key,該參數(shù)可選。

“Mybatisd對(duì)MySQL批量插入語句的方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI