解決mybatis批量更新出現SQL報錯問題

一、問題重現

1.配置文件

spring:
  #DataSource數據源
  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 所用日志的具體實現,未指定時將自動查找
    map-underscore-to-camel-case: true #開啟自動駝峰命名規則(camel case)映射
    lazy-loading-enabled: true #開啟延時加載開關
    aggressive-lazy-loading: false #將積極加載改為消極加載(即按需加載),默認值就是false
    lazy-load-trigger-methods: "" #阻擋不相幹的操作觸發,實現懶加載
    cache-enabled: true #打開全局緩存開關(二級環境),默認值就是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.測試

查看控制臺錯誤

在這裡插入圖片描述

發現這裡告訴我有一個語法錯誤,然後發現user_id,有一個符號。>

這裡經過測試更新一條是成功的

在這裡插入圖片描述

二、問題分析

Mybatis映射文件中的sql語句默認是不支持以" ; " 結尾的,也就是不支持多條sql語句的執行

在這裡插入圖片描述

但是在SQL編輯器中執行多條sql語句的時候是可以以分號結尾的,如:

在這裡插入圖片描述

三、解決方法

在application.properties配置文中的數據源url後面添加一個參數

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

原來的配置文件:

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

現在的配置文件

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

再次測試

在這裡插入圖片描述

到此這篇關於mybatis批量更新出現SQL報錯的文章就介紹到這瞭,更多相關mybatis批量更新出現SQL報錯內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: