关于MyBatis一些小错误,元素内容必须由格式正确的字符数据或标记组成.

时间:2023-01-21 22:52:43

今天在Mapper.xml文件写查询语句报了个奇怪的错误

Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance.  Cause: org.xml.sax.SAXParseException; lineNumber: 30; columnNumber: 45; 元素内容必须由格式正确的字符数据或标记组成。

元素内容必须由格式正确的字符数据或标记组成

当时我的代码如下

<!-- 查询7天的数据 -->
<if test="param.day =='1'">
AND DATE_SUB(CURDATE(), INTERVAL 7 DAY) <=  SEARCH_TIME
</if>
后来来网上查了下发现

原因 : Mapper.xml 文件里  < (小于)号 ,   >(大于)号 ,会被认为是括号,需要额外注意,


解决办法 : 将 < 号换成  &lt;     > 号 换成&gt; 

<if test="param.day =='1'">
AND DATE_SUB(CURDATE(), INTERVAL 7 DAY) &lt;=  SEARCH_TIME
</if>



接下来就不报错了,但是我发现判断 <if test="param.day =='1'">失败,没有进入到if里


原因 :在xml文件直接判断 ' != ' 是可以的 ,判断 ' == ' 会发生冲突


解决办法  :   <if test="param.day =='1'.toString()"> 在判断的参数后加上toString()方法;


本人第一次写博客,希望大家发现博客有错误和我提出,博主会第一时间更新文章.

谢谢.

本人邮箱:zhaitonghui.vip@foxmail.com