mybatis中﹤![CDATA[ ]]> 的使用

问题: mybatis中﹤![CDATA[ ]]> 的使用
描述:

<sql>

 
  1. <!--

  2. WARNING - @mbggenerated

  3. This element is automatically generated by MyBatis Generator, do not modify.

  4. This element was generated on Thu Oct 10 09:46:29 CST 2013.

  5. -->

  6. <if test="page != null">

  7. <![CDATA[ limit #{page.begin}, #{page.length} ) as temp_page_table) ]]>

  8. <if test="orderByClause != null">

  9. order by ${orderByClause}

  10. </if>

  11. </if>

</sql>
上述代码是利用mybatis的generator自动生成的代码,为什么要加﹤![CDATA[ ]]>呢?感觉完全没有必要的啊,里面的SQL语句并没有破坏xml文档结构,或引起sql错误的啊?为什么呢?

=============================================================

补充说明,我知道它的用法,我只是不明白sql的分页
limit #{page.begin}, #{page.length} ) as temp_page_table) 
这个语句,为什么要加<![CDATA[]]>呢?


解决方案1:

W3C XML CDATA
CDATA与MyBatis并没有关系。

术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。CDATA 部分中的所有内容都会被解析器忽略。
至于你的XML中即使没有错误但是也增加了CDATA,楼主也说了是通过generator自动生成的代码,既然是自动生成的那工具自然没有人那么聪明,只用最为通用的方式进行处理,这也无可后非。

解决方案2:

理论上这个limit是没有必要加上这个,我用的limit分页是从来不用加上的,不过具体的你还是测试下,去除掉之后会不会报错,防止"<"这类符号在mybatis中不认

解决方案3:

你这段sql是没有,它应该是统一加的CDATA,防止你的sql里面出现诸如"<"、"&"这种XML非法字符

解决方案4:

在 XML 元素中,"<" 和 "&" 是非法的。
"<" 会产生错误,因为解析器会把该字符解释为新元素的开始。
"&" 也会产生错误,因为解析器会把该字符解释为字符实体的开始。
某些文本,比如 JavaScript 代码,包含大量 "<" 或 "&" 字符。为了避免错误,可以将脚本代码定义为 CDATA。
CDATA 部分中的所有内容都会被解析器忽略。
假设有这么一个SQL

SELECT * FROM users WHERE registerAt > 100

如果不用CDATA封装,xml解析器回去解析,结果遇到">"会导致文档结构错误


以上介绍了“ mybatis中﹤![CDATA[ ]]> 的使用”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/3339853.htm

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值