今天在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 文件里 < (小于)号 , >(大于)号 ,会被认为是括号,需要额外注意,
解决办法 : 将 < 号换成 < > 号 换成>
<if test="param.day =='1'">
AND DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= SEARCH_TIME
</if>
接下来就不报错了,但是我发现判断 <if test="param.day =='1'">失败,没有进入到if里
原因 :在xml文件直接判断 ' != ' 是可以的 ,判断 ' == ' 会发生冲突
解决办法 : <if test="param.day =='1'.toString()"> 在判断的参数后加上toString()方法;
本人第一次写博客,希望大家发现博客有错误和我提出,博主会第一时间更新文章.
谢谢.
本人邮箱:[email protected]