zoukankan      html  css  js  c++  java
  • MyBatis中Mapper.xml文件中的转义字符

    MyBatis中Mapper.xml文件中的转义字符

    一、XML转义字符

    XML只有5个转义符:

    转义符 表达式 说明
    &lt; < 小于号
    &gt; > 大于号
    &amp; &
    &apos; 单引号
    &quot; " 双引号

    值得注意的是:

    • 转义序列字符之间不能有空格;
    • 转义序列必须以”;”结束;
    • 单独出现的”&”不会被认为是转义的开始;
    • 区分大小写。

    但是严格来说,在XML中只有”<”和”&”是非法的,其它三个都是可以合法存在的,但是,把它们都进行转义是一个好的习惯。

    用转义字符进行替换:

    例如,查询年龄<=30 且 >=18的用户 :

    SELECT * FROM user WHERE age &lt;= 30 AND age &gt;= 18
    

    二、<![CDATA[ ]]> 符号

    <![CDATA[]]>这个标记所包含的内容将表示为纯文本,比如<![CDATA[<]]>表示文本内容“<”。

    不管怎么样,转义前的字符也好,转义后的字符也好,都会被xml解析器解析,为了方便起见,使用<![CDATA[]]>来包含不被xml解析器解析的内容。

    但要注意的是:

    • 此部分不能再包含”]]>”;
    • 不允许嵌套使用;
    • "]]>"这部分不能包含空格或者换行。

    所以上面的SQL可以写成这个:

    <![CDATA[ SELECT * FROM  user WHERE  age  <= 30 AND age >= 18 ]]>
    

    最后,说说<![CDATA[]]>和xml转移字符的关系,它们两个看起来是不是感觉功能重复了?

    是的,它们的功能就是一样的,只是应用场景和需求有些不同:

    • <![CDATA[]]>不能适用所有情况,转义字符可以;
    • 对于短字符串<![CDATA[]]>写起来啰嗦,对于长字符串转义字符写起来可读性差;
    • <![CDATA[]]>表示xml解析器忽略解析,所以更快。


    作者:不敲代码的攻城狮
    出处:https://www.cnblogs.com/leigq/
    任何傻瓜都能写出计算机可以理解的代码。好的程序员能写出人能读懂的代码。

     
  • 相关阅读:
    <转载>c#多线程:线程池和异步编程
    <转载>讲故事谈.NET委托:一个C#睡前故事
    IIS 7.0 成员管理配置
    呵呵,新开博!
    PHP函数中文文档
    请不要做浮躁的人对程序员的忠告
    php新闻发布完成
    JS调试工具
    PHP配置FCKEditor
    ACEGI配置总结(1)
  • 原文地址:https://www.cnblogs.com/leigq/p/13406579.html
Copyright © 2011-2022 走看看