当前位置: 首页 > news >正文

MyBatis 配置文件核心


MyBatis 配置文件核心标签解析

以下是针对你的笔记中的三个核心标签的详细解析,帮助你全面理解它们的用途和配置逻辑。


1. properties 标签:动态加载外部配置

功能
  • 将环境相关的配置(如数据库连接、密钥等)与 MyBatis 核心配置解耦。
  • 允许在多个环境中(开发、测试、生产)快速切换配置。
属性
属性名用途示例
resource从类路径加载配置文件resource="jdbc.properties"
url从文件系统或网络路径加载url="file:///C:/config/jdbc.properties"
配置示例
 
<!-- mybatis-config.xml --> <configuration> <!-- 加载外部配置文件 --> <properties resource="jdbc.properties" /> <environments default="dev"> <environment id="dev"> <dataSource type="POOLED"> <property name="driver" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </dataSource> </environment> </environments> </configuration> 
外部配置文件内容 (jdbc.properties)
 
jdbc.driver=com.mysql.cj.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/mydb?useSSL=false&serverTimezone=UTC jdbc.username=root jdbc.password=123456 
易错点
  • ❌ 路径错误:resource 指向的文件不在 resources 目录中。
  • ❌ 未转义特殊字符:& 需要用 &amp; 转义(如 Redis 配置中的 &timeout=1000)。

2. settings 标签:全局行为控制

功能
  • 控制 MyBatis 的底层运行机制,如日志、缓存、驼峰映射等。
  • 需严格按照官方文档配置参数和值类型。
常用配置项
设置名称(name)作用默认值
mapUnderscoreToCamelCase数据库下划线字段(user_name)自动映射到 Java 驼峰属性(userNamefalse
cacheEnabled是否开启二级缓存true
logImpl指定日志框架实现(SLF4J、Log4J2 等)无默认
配置示例
 
<configuration> <settings> <!-- 开启驼峰自动映射 --> <setting name="mapUnderscoreToCamelCase" value="true"/> <!-- 配置日志实现 --> <setting name="logImpl" value="SLF4J"/> </settings> </configuration> 
使用场景
  • 场景 1:数据库字段为 user_name ,Java 类属性为 userName → 需设置 mapUnderscoreToCamelCase=true,否则需手动映射。
  • 场景 2:需要精细化控制缓存 → 调整 cacheEnabled 并配合 @CacheNamespace 注解。

3. typeAliases 标签:简化类名引用

功能
  • 为 Java 类型定义短别名,避免在 XML 中反复写全类名。
子标签示例
  • 子标签 1:typeAlias(单个类定义别名)

     
    <typeAliases> <!-- alias="user" 可自定义别名 --> <typeAlias type="com.example.entity.User" alias="user" /> </typeAliases> 
  • 子标签 2:package(批量扫描包)

     
    <typeAliases> <!-- 自动注册包下的所有类,默认别名 = 类名的小写形式(如 User → user) --> <package name="com.example.entity"/> </typeAliases> 
覆盖默认别名

通过 @Alias 注解自定义别名:

 
package com.example.entity; @Alias("employee") public class User { // ... } 

整体配置示例

 
<!-- mybatis-config.xml --> <configuration> <!-- 加载外部配置 --> <properties resource="config/jdbc.properties" /> <!-- 全局设置 --> <settings> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings> <!-- 别名定义 --> <typeAliases> <package name="com.example.entity"/> </typeAliases> <!-- 环境配置 --> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="${jdbc.driver}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> </dataSource> </environment> </environments> <!-- 映射器注册 --> <mappers> <mapper resource="mapper/UserMapper.xml"/> </mappers> </configuration> 

总结与思考

  • 灵活性properties 让配置适应不同环境,settings 调试框架行为,typeAliases 提升代码简洁性。
  • 典型错误:配置文件路径错误、别名未被扫描到、setter/getter 缺失导致属性映射失败。
  • 附加学习:结合 @Alias 注解和 ResultMap 处理复杂映射场景。

需要通过实际项目练习这些配置的使用,才能深刻理解每个标签的“边界”(何时必须用,何时可省略)。例如:当你的实体类名和数据库表字段已经严格符合驼峰规则时,可能不需要开启 mapUnderscoreToCamelCase

相关文章:

  • c++实现在同一台主机两个程序实现实时通信
  • 阿里推出全新推理模型(因果语言模型),仅1/20参数媲美DeepSeek R1
  • ABB 继电器和晶体管输出端子使用
  • 双指针算法
  • 介绍一个能支持高带宽的EDID编辑软件
  • SpringCloud系列教程(十三):Sentinel流量控制
  • python脚本py文件加密 pyarmor
  • Linux - 文件
  • 算法之 前缀和
  • 力扣132. 分割回文串 II
  • 传统工厂转型实录:1套WMS系统如何砍掉40%仓储成本
  • 信奥赛CSP-J复赛集训(DP专题)(16):P1203 [USACO1.1] 坏掉的项链 Broken Necklace
  • 【Qt QML】Loader动态加载组件
  • 【SegRNN 源码理解】图示理解 forward的过程
  • Kanna 与 Swift:结合使用提升网络请求效率
  • vue3,Element Plus中隐藏树el-tree滚动条
  • AIP-160 过滤
  • 采用OllamaSharp实现.NET快速对接deepseek实现聊天、模型管理、流式响应等功能
  • 统计作业提交情况python脚本
  • css错峰布局/瀑布流样式(类似于快手样式)
  • 简单建站的网站/湖南长沙seo教育
  • 专业网站设计方案公司/网络网站推广
  • 网站模板免费下载php/优化游戏性能的软件
  • 微盟小程序官网/百度竞价优化软件
  • wordpress网站导航菜单插件/怎样做网站平台
  • 制作网页时一般使用什么对网页进行布局/图片优化是什么意思