解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問題
一、問題重現(xiàn)
1.配置文件
spring: #DataSource數(shù)據(jù)源 datasource: url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false& 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 #開啟自動(dòng)駝峰命名規(guī)則(camel case)映射 lazy-loading-enabled: true #開啟延時(shí)加載開關(guān) aggressive-lazy-loading: false #將積極加載改為消極加載(即按需加載),默認(rèn)值就是false lazy-load-trigger-methods: "" #阻擋不相干的操作觸發(fā),實(shí)現(xiàn)懶加載 cache-enabled: true #打開全局緩存開關(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ò)誤
發(fā)現(xiàn)這里告訴我有一個(gè)語法錯(cuò)誤,然后發(fā)現(xiàn)user_id,有一個(gè)符號(hào)。>
這里經(jīng)過測(cè)試更新一條是成功的
二、問題分析
Mybatis映射文件中的sql語句默認(rèn)是不支持以" ; " 結(jié)尾的,也就是不支持多條sql語句的執(zhí)行
但是在SQL編輯器中執(zhí)行多條sql語句的時(shí)候是可以以分號(hào)結(jié)尾的,如:
三、解決方法
在application.properties配置文中的數(shù)據(jù)源url后面添加一個(gè)參數(shù)
&allowMultiQueries=true【允許sql語句中有多個(gè)insert或者update語句 == 支持sql批量操作】
原來的配置文件:
url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false&
現(xiàn)在的配置文件
url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false&&&allowMultiQueries=true
再次測(cè)試
到此這篇關(guān)于mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)的文章就介紹到這了,更多相關(guān)mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入解析Spring Bean初始化時(shí)和銷毀時(shí)的擴(kuò)展點(diǎn)
在Bean進(jìn)行初始化或者銷毀的時(shí)候,如果我們需要做一些操作,比如加載和銷毀一些資源或者執(zhí)行一些方法時(shí),那么就可以使用Spring提供的一些擴(kuò)展,今天主要分享初始化Bean時(shí)的三種方式和銷毀Bean時(shí)的三種方式,需要的朋友可以參考下2023-08-08Java?SM2加密相關(guān)實(shí)現(xiàn)與簡單原理詳解
SM2算法可以用較少的計(jì)算能力提供比RSA算法更高的安全強(qiáng)度,而所需的密鑰長度卻遠(yuǎn)比RSA算法低,這篇文章主要給大家介紹了關(guān)于Java?SM2加密相關(guān)實(shí)現(xiàn)與簡單原理的相關(guān)資料,需要的朋友可以參考下2024-01-01解析spring-security權(quán)限控制和校驗(yàn)的問題
這篇文章主要介紹了解析spring-security權(quán)限控制和校驗(yàn)的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03詳解spring security四種實(shí)現(xiàn)方式
這篇文章主要介紹了詳解spring security四種實(shí)現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11SSH框架網(wǎng)上商城項(xiàng)目第21戰(zhàn)之詳解易寶支付的流程
這篇文章主要為大家詳細(xì)介紹了SSH框架網(wǎng)上商城項(xiàng)目第21戰(zhàn)之易寶支付的流程,感興趣的小伙伴們可以參考一下2016-06-06spring定時(shí)任務(wù)(scheduler)的串行、并行執(zhí)行實(shí)現(xiàn)解析
這篇文章主要介紹了spring定時(shí)任務(wù)(scheduler)的串行、并行執(zhí)行實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09使用springBoot項(xiàng)目配置文件位置調(diào)整到打包外
這篇文章主要介紹了使用springBoot項(xiàng)目配置文件位置調(diào)整到打包外,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-08-08Java如何通過線程解決生產(chǎn)者/消費(fèi)者問題
這篇文章主要介紹了Java如何通過線程解決生產(chǎn)者/消費(fèi)者問題,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-10-10Java函數(shù)式編程(一):你好,Lambda表達(dá)式
這篇文章主要介紹了Java函數(shù)式編程(一):你好,Lambda表達(dá)式,本文講解了新老函數(shù)式編程的一些變化,需要的朋友可以參考下2014-09-09