XML Mapper是什么 如何在MyBatis中用它来编写SQL
技术百科
煙雲
发布时间:2026-01-20
浏览: 次 XML Mapper 是 MyBatis 中定义 SQL 映射关系的 XML 文件,用于解耦 Java 接口方法与 SQL 语句,需满足命名、路径约定并显式配置才能被正确加载。
XML Mapper 是什么
XML Mapper 是 MyBatis 中用于定义 SQL 映射关系的 XML 文件,它把 Java 接口方法和 SQL 语句解耦,让 SQL 集中管理、便于维护。它不是运行时生成的代理类,也不是注解替代品——而是 MyBatis 加载 Mapper 接口时,按命名约定查找并绑定的外部 SQL 定义载体。
如何让 MyBatis 找到并加载 XML Mapper 文件
MyBatis 不会自动扫描任意路径下的 XML 文件,必须满足命名与路径双重约定:
- XML 文件名必须和对应
Mapper接口类名一致(如UserMapper.java→UserMapper.xml) - XML 文件必须放在与接口相同的包路径下(如
com.example.mapper.UserMapper对应resources/com/example/mapper/UserMapper.xml) - 在
mybatis-config.xml或 Spring Boot 的application.yml中显式配置 mapper 路径(Spring Boot 默认扫描mapper-locations: classpath*:mapper/**/*.xml,但若改过包结构或用了非标准路径,就得手动配)
常见错误:IDE 编译后 .xml 没进 target/classes —— 检查 pom.xml 是否漏了 resources 配置,Maven 默认不复制非 *.java 文件到输出目录。
XML Mapper 中写 SQL 的基本结构
每个 UserMapper.xml 必须有 根标签,并通过 namespace 绑定接口全限定名。SQL 语句用 、 等标签包裹,id 必须和接口方法名一致。
注意点:
-
#{id}是预编译参数占位符,防 SQL 注入;${id}是字符串拼接,仅用于动态表名/列名等极少数场景 -
resultType和resultMap二选一:resultType适用于字段名与 POJO 属性名完全匹配;复杂映射(如字段别名、嵌套对象、类型转换)必须用 - MyBatis 3.4+ 支持在 XML 中使用
或 OGNL 表达式做简单逻辑,但别写业务逻辑——XML 只管 SQL 结构,不该承担判断职责
为什么有时 XML Mapper 没生效?几个典型卡点
不是语法错,而是绑定失败或加载遗漏,最常发生在以下环节:
- 接口方法有重载(如两个
findById),XML 中id冲突 → MyBatis 只认名字,不看参数,直接报BindingException: Invalid bound statement - XML 文件编码不是 UTF-8,含中文注释或字段名时乱码 → 导致解析失败,日志里可能只报 “Error parsing SQL Mapper” 无明细
- 用了
@MapperScan但没扫到 XML 所在包,或用了@Mapper注解在接口上却忘
了加
@MapperScan(后者仅对当前接口有效,不递归子包) - Spring Boot + MyBatis-Plus 混用时,MP 默认禁用 XML(
mybatis-plus.configuration.map-underscore-to-camel-case=false不影响 XML,但 MP 的自动扫描可能绕过 XML)→ 查MybatisConfiguration日志确认是否加载了该 XML
调试建议:启动时加 logging.level.org.apache.ibatis=DEBUG,看日志里有没有 MapperRegistry.addMapper 和 XMLMapperBuilder.parse 成功记录。
# 几个
# 加载
# 用了
# 适用于
# 绑定
# 就得
# app
# 在与
# Error
# 递归
# 对象
# java
# 编码
# xml
# 字符串
# 接口
# 为什么
# map
# select
# 类型转换
# sql
# apache
# spring
# Namespace
# 不看
# ide
# 字段名
# Logging
# spring boot
# maven
# mybatis
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Windows的便笺功能如何使用?(桌面备忘技巧)
- Windows如何设置登录时的欢迎屏幕背景?(锁屏
- Win11用户账户控制怎么关_Win11关闭UAC
- Win11怎么查看wifi信号强度_检测Windo
- Win11怎么设置屏保_Windows 11屏幕保
- Windows10怎么备份注册表_Windows1
- c++ stringstream用法详解_c++字
- Win11怎么开启HDR模式_Windows 11
- 如何在 ACF 中正确更新嵌套多层 Group 字
- 如何在 Go 中调用动态链接库(.so)中的函数
- Win11怎么设置声音输出设备_Windows11
- Win10系统怎么查看端口状态_Windows10
- Python多线程使用规范_线程安全解析【教程】
- 如何在Golang中处理URL参数_Golang
- 微信JSAPI支付回调PHP怎么接收_处理JSAP
- 如何使用Golang log设置日志输出格式_Go
- 微信里的php文件怎么变mp4_微信接收php转m
- C++如何获取CPU核心数?(std::threa
- MAC怎么用连续互通相机里的“桌上视角”_MAC在
- Windows服务持续崩溃怎样修复_系统服务保护机
- Windows10电脑怎么设置电源按钮_Win10
- php485在php5.6下能用吗_php485旧
- Windows驱动无法加载错误解决方法_驱动签名验
- c++如何判断文件是否存在_c++ filesys
- php485能和物联网模块通信吗_php485对接
- C++中的Pimpl idiom是什么,有什么好处
- Win11怎么开启自动HDR画质_Windows1
- 为什么Go需要go mod文件_Go go mod
- Windows10电脑怎么设置防火墙出站规则_Wi
- php485函数怎么捕获异常_php485错误处理
- Flask 表单数据通过 SMTP 发送邮件的完整
- 如何使用正则表达式提取以编号开头、后跟多个注解的完
- PHP的Workerman对架构扩展有啥帮助_应用
- php内存溢出怎么排查_php内存限制调试与优化方
- php在Linux怎么部署_LNMP环境搭建PHP
- Win11怎么关闭自动维护 Win11禁用系统自动
- Win11相机打不开提示错误怎么修_相机权限开启与
- WindowsUSB驱动安装异常怎么办_USB驱动
- Go 中 := 短变量声明的类型推导机制详解
- 如何使用正则表达式批量替换重复的 *- 模式为固定
- 如何使用Golang理解结构体指针方法接收者_Go
- 如何在Golang中处理数据库事务错误_回滚和日志
- Win10怎样设置闹钟贪睡时间 Win10闹钟贪睡
- 如何使用Golang配置安全开发环境_防止敏感信息
- 如何使用Golang实现容器健康检查_监控和自动重
- Windows怎样关闭开始菜单推荐广告_Windo
- Win11怎么禁用键盘自带键盘_Win11笔记本禁
- MAC如何快速搜索大文件_MAC磁盘空间分析与冗余
- 如何使用 Python 合并文件夹内多个 Exce
- Win11怎么更改管理员名字 Win11修改账户名


QQ客服