mybatis转义反斜杠_MyBatis踩坑之SQLProvider转义字符被删除问题

本文介绍了在使用MyBatis的SQLProvider动态拼装SQL时,遇到MySQL删除反斜杠转义字符的问题。通过分析发现,问题源头在于MySQL的默认配置。提供了两种解决方案:修改MySQL的SQL模式为`NO_BACKSLASH_ESCAPES`或使用PreparedStatement预处理语句。同时,展示了MyBatis注解方式支持XML风格动态SQL配置,以解决批量插入时的转义字符问题。
摘要由CSDN通过智能技术生成

目录

踩坑背景

项目架构:Spring Boot + MyBatis + MySQL。

使用MyBatis作为ORM框架,jdbc驱动使用的是mariadb-java-client。

org.mariadb.jdbc

mariadb-java-client

2.3.0

为了不使用xml形式的配置文件,MyBatis使用接口映射器,并使用映射器注解方式编写SQL语句。

@Mapper

public interface TestDAO {

@Select("select * from test where id = #{id}")

public Test getById(@Param("id") long id);

}

问题描述

在批量添加记录时通过SQLProvider动态拼装SQL,具体代码示例如下所示:

@Repository

@Mapper

public interface TestDAO {

// 使用SQLProvider拼装SQL实现批量插入

@InsertProvider(type = TestProvider.class, method = "addTestBatch")

public Integer addTestBatch(@Param("tests") List tests);

}

public class TestProvid

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值