mybatis中﹤![CDATA[ ]]> 的使用
2017-10-30 21:08
288 查看
问题: mybatis中﹤![CDATA[ ]]> 的使用
描述:
<sql>
</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
如果不用CDATA封装,xml解析器回去解析,结果遇到">"会导致文档结构错误
以上介绍了“ mybatis中﹤![CDATA[ ]]> 的使用”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/3339853.htm
描述:
<sql>
<!-- WARNING - @mbggenerated This element is automatically generated by MyBatis Generator, do not modify. This element was generated on Thu Oct 10 09:46:29 CST 2013. --> <if test="page != null"> <![CDATA[ limit #{page.begin}, #{page.length} ) as temp_page_table) ]]> <if test="orderByClause != null"> order by ${orderByClause} </if> </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
相关文章推荐
- mybatis <![CDATA[ ]]>的作用、使用、注意事项。
- 使用CDATA标签,防止 "<="或者">"与Mybatis的标签冲突
- 【mybatis】<![CDATA[]]>使用方法
- mybatis 中的<![CDATA[ ]]>
- mybatis中的<collection>标签使用说明
- mybatis 中的<![CDATA[ ]]>
- mybatis 中的<![CDATA[ ]]>防止转义xml中特殊字符
- 博为峰JavaEE技术文章 ——MyBatis <where>标签使用方法
- Mybatis传单个参数和<if>标签同时使用的问题及解决方法
- 6.1 Mybatis实现动态SQL——<if></if>使用
- MyBatis中<resultMap>的<association>和<collection>标签的使用
- Mybatis的<where><trim><set>标签使用和排重
- 在使用simplexml_load_file()函数读取xml文件时遇到<![CDATA[]]>,怎么让其进行解析
- <![CDATA[]]>和转义字符 (注:这篇文章是本人在其他地方看到的,刚好项目中mybatis用到了,所以转来分享)
- Mybatis 中的<![CDATA[ ]]>浅析
- Mybatis IBatis的Mapper配置文件中使用大于号好小于号 :>和<
- mybatis 中的<![CDATA[ ]]>
- Mybatis的mapper.xml的传值和<if></if>标签的使用(学习分享)
- mybatis 模糊查询和<![CDATA[ ]]>的作用
- java框架---->mybatis的使用(一)