spring boot 使用 MyBatis编译报错-元素内容必须由格式正确的字符数据或标记组成.

报错内容:
Invocation of init method failed; nested exception is java.lang.IllegalArgumentException: org.apache.ibatis.builder.BuilderException: Could not find value method on SQL annotation. Cause: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 8; columnNumber: 137; 元素内容必须由格式正确的字符数据或标记组成。
报错原因:
当时我的代码如下

AND DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= SEARCH_TIME 后来来网上查了下发现 原因 : Mapper.xml 文件里 < (小于)号 , >(大于)号 ,会被认为是括号,需要额外注意,

解决办法 : 将 < 号换成 < > 号 换成>

AND DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= SEARCH_TIME

接下来就不报错了,但是我发现判断 失败,没有进入到if里
原因 :在xml文件直接判断 ’ != ’ 是可以的 ,判断 ’ == ’ 会发生冲突
解决办法 : 在判断的参数后加上toString()方法;

猜你喜欢

转载自blog.csdn.net/qq_17394183/article/details/89841243