【MyBatis】CDATA标签和xml字符转义

<![CDATA[ ]]>标签

XML 格式不支持解析 “&”、“<”、“>”等符号,这些字符在xml解析的时候会被转义,解决方法

  1. 加上CDATA标签避免报错。在该标签内的语句,将不会被当成字符串来处理,而是直接当成sql语句;
    1. <![CDATA[ ]]>是xml语法,在<![CDATA[ ]]>内部的所有内容都会被解析器忽略,**不进行转义**
    2. 在mybatis中像<if></if>这样的标签如果放在<![CDATA[ ]]>中也会被解析器忽略,所以要尽可能缩小<![CDATA[ ]]>的范围
  2. 转义字符

转义字符

原符号转移符号释义
<&lt;小于
>&gt;大于
&&amp;
&apos;单引号
"&quot;双引号

测试代码

测试代码

<select id="forShow" resultType="java.util.Map">
    select *
    from
    test_table
    where
    <choose>
        <when test='param1 == "1"'>
            ord < 2     <!--  此行代码编译不通过  -->
        </when>
        <when test='param1 == "2"'>
            <![CDATA[ord<2]]>     <!--  ord < 2  -->
        </when>
        <when test='param1 == "3"'>
            ord <![CDATA[<]]> 2   <!--  ord < 2  -->
        </when>
        <when test='param1 == "4"'>
            ord &lt; 2     <!--  ord < 2  -->
        </when>
        <when test='param1 == "5"'>
            ord > 2
        </when>
        <when test='param1 == "6"'>
            TEST_ID = "1"
        </when>
        <when test='param1 == "7"'>
            TEST_ID = '2'
        </when>
    </choose>
</select>

测试结果

经过测试,

  1. 在xml中使用 <的时候是不会通过编译的
  2. >'"三者可以在xml的sql中使用;
  3. &的测试代码有待探究
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值