溫馨提示×

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

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

如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題

發(fā)布時(shí)間:2022-02-19 14:26:35 來(lái)源:億速云 閱讀:296 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

一、問(wèn)題重現(xiàn)

1.配置文件

spring:
  #DataSource數(shù)據(jù)源
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false&amp
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver

#MyBatis配置
mybatis:
  type-aliases-package: com.hl.mybatis.pojo #別名定義
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #指定 MyBatis 所用日志的具體實(shí)現(xiàn),未指定時(shí)將自動(dòng)查找
    map-underscore-to-camel-case: true #開(kāi)啟自動(dòng)駝峰命名規(guī)則(camel case)映射
    lazy-loading-enabled: true #開(kāi)啟延時(shí)加載開(kāi)關(guān)
    aggressive-lazy-loading: false #將積極加載改為消極加載(即按需加載),默認(rèn)值就是false
    lazy-load-trigger-methods: "" #阻擋不相干的操作觸發(fā),實(shí)現(xiàn)懶加載
    cache-enabled: true #打開(kāi)全局緩存開(kāi)關(guān)(二級(jí)環(huán)境),默認(rèn)值就是true

2.sql

@Update({"<script>" +
            "<foreach item='item' collection='list' index='index' open='' close='' separator=';'>" +
            " UPDATE tb_user " +
            "<set>" +
            "<if test='item.userAccount != null'>user_account = #{item.userAccount},</if>" +
            "<if test='item.userPassword != null'>user_password=#{item.userPassword}</if>" +
            "</set>" +
            " WHERE user_id = #{item.userId} " +
            "</foreach>" +
            "</script>"})
    int updateBatch(@Param("list")List<UserInfo> userInfoList);

3.測(cè)試

查看控制臺(tái)錯(cuò)誤

如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題

發(fā)現(xiàn)這里告訴我有一個(gè)語(yǔ)法錯(cuò)誤,然后發(fā)現(xiàn)user_id,有一個(gè)符號(hào)。>

這里經(jīng)過(guò)測(cè)試更新一條是成功的

如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題

二、問(wèn)題分析

Mybatis映射文件中的sql語(yǔ)句默認(rèn)是不支持以" ; " 結(jié)尾的,也就是不支持多條sql語(yǔ)句的執(zhí)行

如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題

但是在SQL編輯器中執(zhí)行多條sql語(yǔ)句的時(shí)候是可以以分號(hào)結(jié)尾的,如:

如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題

三、解決方法

在application.properties配置文中的數(shù)據(jù)源url后面添加一個(gè)參數(shù)

&allowMultiQueries=true【允許sql語(yǔ)句中有多個(gè)insert或者update語(yǔ)句 == 支持sql批量操作】

原來(lái)的配置文件:

url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false&amp

現(xiàn)在的配置文件

url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false&amp&&allowMultiQueries=true

再次測(cè)試

如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題

以上是“如何解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

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

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

AI