欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 高考 > MyBatis xml 文件中 SQL 语句的小于号未转义导致报错

MyBatis xml 文件中 SQL 语句的小于号未转义导致报错

2025/5/4 7:39:43 来源:https://blog.csdn.net/kwok924/article/details/143632422  浏览:    关键词:MyBatis xml 文件中 SQL 语句的小于号未转义导致报错

问题现象

在 MyBatis 的 xml 文件中添加了一个 SQL 语句

<select id="countXxx" resultType="int">select count(*) from t1 where count < 3
</select>

启动 Spring Boot 应用程序后报错:

Caused by: org.apache.ibatis.builder.BuilderException: Error creating document instance.  Cause: org.xml.sax.SAXParseException; lineNumber: 109; columnNumber: 104; 元素内容必须由格式正确的字符数据或标记组成。at org.apache.ibatis.parsing.XPathParser.createDocument(XPathParser.java:263) ~[mybatis-3.5.6.jar:3.5.6]at org.apache.ibatis.parsing.XPathParser.<init>(XPathParser.java:127) ~[mybatis-3.5.6.jar:3.5.6]at org.apache.ibatis.builder.xml.XMLMapperBuilder.<init>(XMLMapperBuilder.java:81) ~[mybatis-3.5.6.jar:3.5.6]at com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean.buildSqlSessionFactory(MybatisSqlSessionFactoryBean.java:592) ~[mybatis-plus-extension-3.4.2.jar:3.4.2]... 72 common frames omitted
Caused by: org.xml.sax.SAXParseException: 元素内容必须由格式正确的字符数据或标记组成。at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:203) ~[na:1.8.0_162]at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:177) ~[na:1.8.0_162]at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:400) ~[na:1.8.0_162]at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:327) ~[na:1.8.0_162]

IntelliJ IDEA 也提示了:

问题原因

这个问题的原因不符合是 XML 文件的语法,因为小于号 < 和 XML 文件的标签符号是一样的,所以在 XML 文件中使用小于号时要使用转义符号 <

修改方法

<!-- 小于 -->
<select id="countXxx" resultType="int">select count(*) from t1 where count &lt; 3
</select><!-- 小于等于 -->
<select id="countXxx" resultType="int">select count(*) from t1 where count &lt;= 3
</select>

参考

  • https://www.w3schools.com/xml/xml_syntax.asp

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词