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

问题现象

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

xml 复制代码
<select id="countXxx" resultType="int">
        select count(*) from t1 where count < 3
</select>

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

shell 复制代码
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 文件中使用小于号时要使用转义符号 <

修改方法

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>

参考

相关推荐
Alfredorw1 小时前
Mybatis-Plus的使用
mybatis
Meepo_haha3 小时前
配置MyBatis-Plus打印执行的 SQL 语句到控制台或日志文件中
数据库·sql·mybatis
极创信息4 小时前
企业信创产品认证全流程:从信创适配到信创认证的实操指南(2026版)
java·数据库·spring boot·mysql·matlab·mybatis·软件工程
神舟之光7 小时前
Springboot+MyBatis-Plus连接MySQL初体验
spring boot·mysql·mybatis
Echo27177 小时前
mybatis的知识点总结
mybatis
小江的记录本1 天前
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
java·前端·spring boot·后端·spring·mybatis·web
小飞Coding1 天前
MyBatis Mapper 实现原理彻底解密——从动态代理到 JDBC 执行全链路剖析
后端·mybatis
华科易迅1 天前
MybatisPlus乐观锁
java·开发语言·mybatis
野犬寒鸦1 天前
Redis复习记录Day03
服务器·redis·后端·面试·bootstrap·mybatis
爱丽_1 天前
MyBatis 性能优化:批处理、分页、缓存与慢 SQL 定位
缓存·性能优化·mybatis