0

0

XML Mapper是什么 如何在MyBatis中用它来编写SQL

煙雲

煙雲

发布时间:2026-01-20 10:17:02

|

589人浏览过

|

来源于php中文网

原创

xml mapper 是 mybatis 中定义 sql 映射关系的 xml 文件,用于解耦 java 接口方法与 sql 语句,需满足命名、路径约定并显式配置才能被正确加载。

xml mapper是什么 如何在mybatis中用它来编写sql

XML Mapper 是什么

XML Mapper 是 MyBatis 中用于定义 SQL 映射关系的 XML 文件,它把 Java 接口方法和 SQL 语句解耦,让 SQL 集中管理、便于维护。它不是运行时生成的代理类,也不是注解替代品——而是 MyBatis 加载 Mapper 接口时,按命名约定查找并绑定的外部 SQL 定义载体。

如何让 MyBatis 找到并加载 XML Mapper 文件

MyBatis 不会自动扫描任意路径下的 XML 文件,必须满足命名与路径双重约定:

  • XML 文件名必须和对应 Mapper 接口类名一致(如 UserMapper.javaUserMapper.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 必须有 <mapper></mapper> 根标签,并通过 namespace 绑定接口全限定名。SQL 语句用 <select></select><insert></insert> 等标签包裹,id 必须和接口方法名一致。

LogoAi
LogoAi

利用AI来设计你喜欢的Logo和品牌标志

下载
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper">
  <select id="findById" resultType="com.example.model.User">
    SELECT * FROM user WHERE id = #{id}
  </select>
</mapper>

注意点:

  • #{id} 是预编译参数占位符,防 SQL 注入;${id} 是字符串拼接,仅用于动态表名/列名等极少数场景
  • resultTyperesultMap 二选一:resultType 适用于字段名与 POJO 属性名完全匹配;复杂映射(如字段别名、嵌套对象、类型转换)必须用 <resultmap></resultmap>
  • MyBatis 3.4+ 支持在 XML 中使用 <bind></bind> 或 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.addMapperXMLMapperBuilder.parse 成功记录。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1110

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2069

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1602

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

439

2024.04.29

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.2万人学习

C# 教程
C# 教程

共94课时 | 10.9万人学习

Java 教程
Java 教程

共578课时 | 78.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号