MyBatis 的 XML 文件中特殊字符的处理方法

 更新时间:2026年02月06日 10:48:45   作者:Pluto_CSND  
MyBatis XML文件中处理大于、小于等特殊字符的方法,包括使用XML转义字符、CDATA区段、动态SQL中的处理、转义字符对照表、特殊场景处理以及编写辅助函数,本文介绍MyBatis的XML文件中特殊字符的处理,感兴趣的朋友一起看看吧

在 MyBatis 的 XML 文件中,大于符号 > 和小于符号 < 是 XML 的保留字符,当SQL语句中包含这些符号时需要进行特殊处理。以下是几种解决方案:

1、使用 XML 转义字符(推荐)

<!-- 使用 > 表示大于号,>= 表示大于等于号,< 表示小于号,<= 表示小于等于号, -->
<select id="selectByDateRange" resultType="Order">
    SELECT * FROM orders
    WHERE order_date >= #{startDate}
    AND order_date <= #{endDate}
</select>
<select id="selectByIdsWithCondition" resultType="User">
    SELECT * FROM users
    WHERE id IN
    <foreach collection="ids" item="id" open="(" separator="," close=")">
        #{id}
    </foreach>
    AND status < 3  <!-- 必须转义 -->
    ORDER BY create_time DESC
</select>

2、使用 CDATA 区段包裹 SQL

<!-- 使用 <![CDATA[ ]]> 包裹 SQL -->
<select id="selectByDateRange" resultType="Order">
    <![CDATA[
    SELECT * FROM orders
    WHERE order_date >= #{startDate}
    AND order_date <= #{endDate}
    ]]>
</select>

3、动态 SQL 中的大/小于号同样处理

<if> 标签中使用

<select id="selectByCondition" resultType="User">
    SELECT * FROM users
    WHERE 1=1
    <if test="minAge != null">
        AND age > #{minAge}
    </if>
    <if test="maxAge != null">
        AND age < #{maxAge}
    </if>
    <if test="endTime != null">
        <![CDATA[ AND create_time < #{endTime} ]]>
    </if>
</select>

<choose> 标签中使用

<select id="selectByType" resultType="User">
    SELECT * FROM users
    <where>
        <choose>
            <when test="type == 'young'">
                AND age < 30
            </when>
            <when test="type == 'middle'">
                <![CDATA[ AND age >= 30 AND age < 50 ]]>
            </when>
            <when test="type == 'senior'">
                AND age >= 50
            </when>
        </choose>
    </where>
</select>

4、完整的转义字符对照表

符号	XML实体	描述	    示例
-------------------------------------------
>	>	大于号	    age > 18
>=	>=	大于等于号	age >= 18
<	<	小于号	    age < 30
<=	<	小于等于号	age <= 30
&	&	和号	        name & address
'	&apos;	单引号	    name = &apos;John&apos;
"	&quot;	双引号	    name = &quot;John&quot;

5、特殊场景处理

动态表名/列名中的小于号

<!-- 在 ${} 中也需要转义 -->
<select id="selectWithDynamicColumn" resultType="map">
    SELECT ${columnName} as value
    FROM ${tableName}
    WHERE ${columnName} < #{threshold}
</select>

BETWEEN 和小于号的组合

<select id="selectByMultipleConditions" resultType="User">
    SELECT * FROM users
    WHERE 
        <!-- 使用 BETWEEN -->
        age BETWEEN #{minAge} AND #{maxAge}
        <!-- 结合小于号条件 -->
        <if test="maxScore != null">
            <![CDATA[ AND score < #{maxScore} ]]>
        </if>
        <!-- 使用转义字符 -->
        AND level < #{maxLevel}
</select>

6、编写辅助函数

// Java 工具类:自动转义 XML 特殊字符
public class XmlEscapeUtil {
    public static String escapeSqlForXml(String sql) {
        return sql.replace("&", "&")
                  .replace("<", "<")
                  .replace(">", ">")
                  .replace("\"", "&quot;")
                  .replace("'", "&apos;");
    }
    // 使用示例
    public static void main(String[] args) {
        String sql = "SELECT * FROM users WHERE age < 30 AND status > 0";
        System.out.println(escapeSqlForXml(sql));
        // 输出: SELECT * FROM users WHERE age < 30 AND status > 0
    }
}

最后:对于包含 <、> 的简单条件,使用 < 和 > 转义;对于包含大量特殊字符的复杂 SQL,使用 <![CDATA[ ]]> 包裹。

到此这篇关于MyBatis 的 XML 文件中特殊字符的处理的文章就介绍到这了,更多相关MyBatis XML特殊字符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于SpringBoot打造RESTful API实战指南

    基于SpringBoot打造RESTful API实战指南

    本文详细介绍了RESTful API的基本概念、设计规范以及与非RESTful风格的对比,通过Spring Boot实战部分,展示了如何实现一个简单的RESTful API,需要的朋友可以参考下
    2025-12-12
  • Java字符串中有多个分隔符的处理方式

    Java字符串中有多个分隔符的处理方式

    这篇文章主要介绍了Java字符串中有多个分隔符的处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • Linux系统中检查Java版本的三种高效方法

    Linux系统中检查Java版本的三种高效方法

    本文介绍了在Linux系统中检查Java版本的三种高效方法,并探讨了Java版本的重要性及其检查原因,通过了解Java版本格式和不同方法,用户可以确保应用的兼容性、性能和安全性,需要的朋友可以参考下
    2025-12-12
  • java词法分析器DDL递归应用详解

    java词法分析器DDL递归应用详解

    这篇文章主要介绍了java词法分析器DDL递归应用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • springboot+vue实现阿里云oss大文件分片上传的示例代码

    springboot+vue实现阿里云oss大文件分片上传的示例代码

    阿里云推出了直传,本文主要介绍了springboot+vue实现阿里云oss大文件分片上传的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • Java生成堆内存dump的问题

    Java生成堆内存dump的问题

    这篇文章主要介绍了Java生成堆内存dump的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Spring 4.1+JSONP的使用指南

    Spring 4.1+JSONP的使用指南

    在解释JSONP之前,我们需要了解下”同源策略“,这对理解跨域有帮助。基于安全的原因,浏览器是存在同源策略机制的,同源策略阻止从一个源加载的文档或脚本获取或设置另一个源加载额文档的属性。说的简单点就是浏览器限制脚本只能和同协议、同域名、同端口的脚本进行交互。
    2016-04-04
  • SpringBoot3各种配置的优先级对比小结

    SpringBoot3各种配置的优先级对比小结

    SpringBoot3提供了多种配置来源以满足不同场景下的需求,本文详细介绍了SpringBoot3中的配置优先级对比小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-12-12
  • SSH框架网上商城项目第24战之Struts2中处理多个Model请求的方法

    SSH框架网上商城项目第24战之Struts2中处理多个Model请求的方法

    这篇文章主要为大家详细介绍了SSH框架网上商城项目第24战之Struts2中处理多个Model请求的方法,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • Spring Boot集成JavaMailSender发送邮件功能的实现

    Spring Boot集成JavaMailSender发送邮件功能的实现

    spring提供了发送邮件的接口JavaMailSender,通过JavaMailSender可以实现后端发送邮件,下面这篇文章主要给大家介绍了关于Spring Boot集成JavaMailSender发送邮件功能的相关资料,需要的朋友可以参考下
    2022-05-05

最新评论