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

 我_纯情至上 发布于 2022-10-28 01:05



  
  
    order by ${orderByClause}
  


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

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

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

4 个回答
  • W3C XML CDATA
    CDATA与MyBatis并没有关系。

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

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

    2022-10-29 07:35 回答
  • 你这段sql是没有,它应该是统一加的CDATA,防止你的sql里面出现诸如"<"、"&"这种XML非法字符

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

    SELECT * FROM users WHERE registerAt > 100

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

    2022-10-29 07:40 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有