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

Mybatis中一條SQL使用兩個(gè)foreach的問題及解決

 更新時(shí)間:2022年02月08日 10:15:00   作者:坑貨行不行  
這篇文章主要介紹了Mybatis中一條SQL使用兩個(gè)foreach的問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一條SQL使用兩個(gè)foreach的問題

未修改前的 SQL 語句

<select id="findQuestionType_3_correct" resultType="map">
    SELECT q.`id`, q.`questionContent`, GROUP_CONCAT(o.`questionOption`) AS questionOptionList 
    FROM `exam_question` q
    INNER JOIN `exam_question_option` o ON q.`id` = o.`questionId` 
    WHERE q.`id` IN 
        <foreach item="ids_1" collection="array" open="(" separator="," close=")" >
            #{ids_1}
        </foreach> 
        AND q.`questionType` = 3 AND o.`correct` = 1 
    GROUP BY FIELD(q.`id`, 
        <foreach item="ids_2" collection="array" separator="," >
            #{ids_2}
        </foreach> 
    )
</select>

這里注意一個(gè)點(diǎn),我兩個(gè) foreach 的 collection 參數(shù)都是:array;

這在只有一個(gè) foreach 的情況下,代碼是能跑通的,沒錯(cuò)我后臺(tái)給的參數(shù)是一個(gè) int[];

因?yàn)闃I(yè)務(wù)需求,我又加了一個(gè) foreach,同樣, collection 參數(shù)給的還是:array;

但是,運(yùn)行時(shí)代碼就報(bào)錯(cuò)了,

報(bào)錯(cuò)如下

???啥情況,四個(gè)參數(shù)???我只給了兩個(gè)參數(shù)啊???SQL 兩個(gè)參數(shù),Dao 層我也沒給 4 個(gè)啊

這個(gè) array 參數(shù)是個(gè)什么鬼?

最后,差不多邊查邊改了兩個(gè)多小時(shí),發(fā)現(xiàn)問題;

將 foreach 的 collection 參數(shù)值分別改為對(duì)應(yīng)的 ids_1 和 ids_2,即可;

代碼如下:

<select id="findQuestionType_3_correct" resultType="map">
    SELECT q.`id`, q.`questionContent`, GROUP_CONCAT(o.`questionOption`) AS questionOptionList 
    FROM `exam_question` q 
    INNER JOIN `exam_question_option` o ON q.`id` = o.`questionId` 
    WHERE q.`id` IN 
        <foreach item="ids_1" collection="ids_1" open="(" separator="," close=")" >
            #{ids_1}
        </foreach> 
        AND q.`questionType` = 3 AND o.`correct` = 1 
    GROUP BY FIELD(q.`id`, 
        <foreach item="ids_2" collection="ids_2" separator="," >
            #{ids_2}
        </foreach> 
    )
</select>

跑是跑通了,但是這樣只是 知其然不知其所以然,于是我在網(wǎng)上查閱了下資料,果然:

當(dāng)查詢有多個(gè)參數(shù)時(shí),foreach 的 collection 屬性可以指定名稱;

查閱文章為:Mybatis List列表In查詢實(shí)現(xiàn)的注意事項(xiàng)

foreach執(zhí)行多條sql報(bào)錯(cuò)的解決

今天在用mybatis執(zhí)行foreach更新操作時(shí)報(bào)了奇怪的錯(cuò)誤.sql語句是沒有任何問題的.sql拿出來直接能運(yùn)行.但是mybatis就是不能運(yùn)行.

而我傳遞一條數(shù)據(jù)的話mybatis能運(yùn)行,但是兩條以上數(shù)據(jù)就會(huì)報(bào)錯(cuò)

后來發(fā)現(xiàn)是mysql不支持執(zhí)行多條sql語句.為此需要再數(shù)據(jù)源后面加上一句話.就可以執(zhí)行多條sql了

&allowMultiQueries=true

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

相關(guān)文章

  • Java文本編輯器實(shí)現(xiàn)方法詳解

    Java文本編輯器實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了Java文本編輯器實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了java文本編輯器結(jié)構(gòu)、原理、布局、實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2019-03-03
  • SpringBoot集成redis實(shí)現(xiàn)分布式鎖的示例代碼

    SpringBoot集成redis實(shí)現(xiàn)分布式鎖的示例代碼

    這篇文章主要介紹了SpringBoot集成redis實(shí)現(xiàn)分布式鎖的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Java中四種9*9乘法表的實(shí)現(xiàn)方式(附代碼)

    Java中四種9*9乘法表的實(shí)現(xiàn)方式(附代碼)

    這篇文章主要介紹了Java中四種9*9乘法表的實(shí)現(xiàn)方式(附代碼),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Spring通過配置文件和注解實(shí)現(xiàn)屬性賦值

    Spring通過配置文件和注解實(shí)現(xiàn)屬性賦值

    這篇文章主要介紹了Spring通過配置文件和注解實(shí)現(xiàn)屬性賦值,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • SpringBoot整合FTP實(shí)現(xiàn)文件傳輸?shù)牟襟E

    SpringBoot整合FTP實(shí)現(xiàn)文件傳輸?shù)牟襟E

    這篇文章主要給大家介紹了SpringBoot整合FTP實(shí)現(xiàn)文件傳輸?shù)牟襟E,文中的流程步驟和代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-11-11
  • java中如何判斷對(duì)象是否是垃圾

    java中如何判斷對(duì)象是否是垃圾

    這篇文章主要介紹了java中如何判斷對(duì)象是否是垃圾,Java有兩種算法判斷對(duì)象是否是垃圾:引用計(jì)數(shù)算法和可達(dá)性分析算法,需要的朋友可以參考下
    2023-04-04
  • Java 駝峰命名法詳解(必看篇)

    Java 駝峰命名法詳解(必看篇)

    下面小編就為大家?guī)硪黄狫ava 駝峰命名法詳解(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • Java獲取文件路徑常用方法解析

    Java獲取文件路徑常用方法解析

    這篇文章主要介紹了Java獲取文件路徑常用方法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • elasticsearch聚合查詢實(shí)踐示例

    elasticsearch聚合查詢實(shí)踐示例

    這篇文章主要為大家介紹了elasticsearch聚合查詢實(shí)踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 如何在IDEA中對(duì) hashCode()和 equals() 利用快捷鍵快速進(jìn)行方法重寫

    如何在IDEA中對(duì) hashCode()和 equals() 利用快捷鍵快速進(jìn)行方法重寫

    這篇文章主要介紹了如何在IDEA中對(duì) hashCode()和 equals() 利用快捷鍵快速進(jìn)行方法重寫,需要的朋友可以參考下
    2020-08-08

最新評(píng)論