原因是 XML 文档中放置了一个类似 “<” 字符,那么这个文档会产生一个错误,这是因为解析器会把它解释为新元素的开始。因此你不能这样写:
<if test="ageStart = null and ageEnd != null ">
and (o.patient_age <= #{ageEnd,jdbcType=TIMESTAMP} )
</if>
正确的写法是这样:
<if test="ageStart = null and ageEnd != null ">
and (o.patient_age <![CDATA[ <= ]]> #{ageEnd,jdbcType=TIMESTAMP} )
</if>
所有 XML 文档中的文本均会被解析器解析。
只有 CDATA 区段(CDATA section)中的文本会被解析器忽略。
- 术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。
- 在 XML 元素中,”<” 和 “&” 是非法的。
- “<” 会产生错误,因为解析器会把该字符解释为新元素的开始。
- “&” 也会产生错误,因为解析器会把该字符解释为字符实体的开始。
- 某些文本,比如 JavaScript 代码,包含大量 “<” 或 “&” 字符。为了避免错误,可以将脚本代码定义为 CDATA。
CDATA 部分中的所有内容都会被解析器忽略。
<script> <![CDATA[ function matchwo(a,b) { if (a < b && a < 0) then { return 1; } else { return 0; } } ]]> </script>
- 在 XML 中有 5 个预定义的实体引用:
< < 小于
> > 大于
& & 和号
' ' 省略号 " " 引号
注释:严格地讲,在 XML 中仅有字符 “<”和”&” 是非法的。省略号、引号和大于号是合法的,但是把它们替换为实体引用是个好的习惯。