Mybatis Mapper XML文件怎么写 Mybatis SQL映射文件编写指南

php中文网
发布: 2025-12-14 15:35:04
原创
113人浏览过
MyBatis Mapper XML 文件需规范命名与路径、正确配置 namespace 和 id,合理使用 #{} 与 ${} 传参,显式定义 resultMap 处理结果映射,善用动态 SQL 标签提升灵活性与安全性。

mybatis mapper xml文件怎么写 mybatis sql映射文件编写指南

MyBatis 的 Mapper XML 文件本质是把 SQL 语句从 Java 代码里抽出来,集中管理、方便维护。写对的关键不是堆语法,而是理清“谁映射谁”“参数怎么传”“结果怎么回”。下面直接说实用要点。

命名和位置要规范

XML 文件名必须和对应 Mapper 接口名一致(如 UserMapper.java 对应 UserMapper.xml),且放在相同包路径下(或通过 <mappers></mappers> 显式注册)。否则 MyBatis 找不到映射关系,报 Invalid bound statement 错误。

  • 推荐放在 resources/mapper/ 目录下,用 <mapper resource="mapper/UserMapper.xml"></mapper> 注册
  • namespace 必须写全限定名,即对应接口的完整类名(如 com.example.mapper.UserMapper
  • 每个 SQL 语句用 <select></select><insert></insert><update></update><delete></delete> 标签包裹,id 值必须和接口方法名完全一致

参数传递:#{} 和 ${} 别乱用

#{} 是预编译占位符,防 SQL 注入,适用于大多数场景;${} 是字符串拼接,只在动态表名、列名、排序字段等无法预编译的地方才用,且必须确保输入安全。

  • 单个参数:直接写 #{id}#{username}(参数名来自方法形参或 @Param 注解)
  • 多个参数:必须用 @Param("xxx") 注解命名,XML 中用 #{xxx} 引用
  • 对象参数:用点号取属性,如 #{user.username}#{user.createTime}
  • 动态列/表名示例:ORDER BY ${orderByColumn}(注意校验该变量是否白名单)

结果映射:别总依赖自动映射

字段名和属性名不一致时,自动映射(mapUnderscoreToCamelCase=true)能解决部分问题,但复杂场景必须显式配置 <resultmap></resultmap>

Glarity
Glarity

Glarity是一款免费开源的AI浏览器扩展,提供YouTube视频总结、网页摘要、写作工具等功能,支持免费的镜像翻译,电子邮件写作辅助,AI问答等功能。

Glarity 131
查看详情 Glarity
  • 简单一对一:用 <id></id><result></result> 指定列与属性映射
  • 关联查询:用 <association></association>(一对一)或 <collection></collection>(一对多),配合 javaType / ofTyperesultMap 属性
  • 避免写 SELECT *,明确列出字段,防止新增字段干扰映射或影响性能
  • 字段别名要和 resultMap 中的 property 名一致,例如 SELECT user_id AS id, user_name AS username FROM user

动态 SQL:用对标签,少写硬编码

MyBatis 提供了 <if></if><choose></choose><where></where><set></set><foreach></foreach> 等标签,核心是让 SQL 更灵活,同时保持可读性。

  • <where></where> 会智能处理开头的 AND/OR,比手写 WHERE 1=1 干净得多
  • <set></set> 自动剔除末尾逗号,更新语句中推荐使用
  • <foreach></foreach> 遍历集合时,注意 collection(入参集合名)、item(当前元素别名)、open/close/separator 的配合,例如 IN 查询:AND id IN <foreach item="id" collection="ids" open="(" separator="," close=")">#{id}</foreach>
  • 多个条件组合优先用 <choose></choose>(类似 switch),避免嵌套太多 <if></if>

基本上就这些。写 XML 不是炫技,目标是清晰、安全、易维护。每次加一个 SQL,先想清楚参数来源、结果结构、边界情况,再动手写标签——比后期调试省力得多。

以上就是Mybatis Mapper XML文件怎么写 Mybatis SQL映射文件编写指南的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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