在项目编译过程中,会出现如下错误
Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 693; columnNumber: 27; The content of elements must consist of well-formed character data or markup.
at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:263)
at org.apache.ibatis.parsing.XPathParser.<init>(XPathParser.java:127)
at org.apache.ibatis.builder.xml.XMLMapperBuilder.<init>(XMLMapperBuilder.java:81)
at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:592)
... 75 common frames omitted
根据错误提示信息(创建文档实例时出错。原因:xml
异常),然后找到xml
查看
<select id="findYesterdayOrderByGroupBatchId" resultType="com.touchealth.physical.bo.order.OrderBo">
select
*
from
trd_order
where order_state in (1, 2)
and checkup_type = 2
and created_time >= #{startTime}
and created_time <= #{endTime}
and deleted_flag = 0
and group_batch_id in
<foreach collection="groupBatchIds" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</select>
因为语句中有一个小于号“<”,在XML中,会被当成一个页面元素来解析,不会处理为mysql的SQL语句的组成部分
解决办法
1. 只需要对使用大于号, 小于号的地方进行转义即可, 其对应的关系如下表所示
2. 将需要使用特殊字符的SQL语句写在 <![CDATA[...]]> 中, 其中的特殊符号不进行解析
被
<![CDATA[]]>
这个标记所包含的内容将表示为纯文本,比如<![CDATA[<]]>
表示文本内容“<
”。
最后,说说<![CDATA[]]>
和xml
转移字符的关系,它们两个看起来是不是感觉功能重复了?
是的,它们的功能就是一样的,只是应用场景和需求有些不同:
- <![CDATA[]]>不能适用所有情况,转义字符可以;
- 对于短字符串<![CDATA[]]>写起来啰嗦,对于长字符串转义字符写起来可读性差;
- <![CDATA[]]>表示xml解析器忽略解析,所以更快。