关于MyBatis一些小错误,元素内容必须由格式正确的字符数据或标记组成.
今天在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()方法;