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

实战:MyBatis 中 db.properties 的正确配置与最佳实践

在 MyBatis 框架中,数据库配置的管理方式直接影响项目的可维护性和灵活性。本文将通过具体代码示例,详细讲解如何使用 db.properties 实现数据库配置的解耦管理,并对比传统硬编码方式的优劣。

一、两种配置方式的直观对比

传统硬编码方式

mybatis-config.xml 中直接写入数据库连接信息:

<dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/数据库名称?serverTimezone=GMT"/><property name="username" value="用户名"/><property name="password" value="密码"/>
</dataSource>

这种方式的问题显而易见:数据库信息变更时必须修改核心配置文件,且敏感信息直接暴露在配置中。

使用 db.properties 管理配置

1、创建 db.properties 文件

在项目的 resources 目录下创建该文件,专门存放数据库连接参数:

# db.properties
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/数据库名称?serverTimezone=GMT
jdbc.username=用户名
jdbc.password=密码
2、在 mybatis-config.xml  中引用

通过 <properties> 标签加载配置文件,再用 ${key} 语法引用参数:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 加载 db.properties 文件 --><properties resource="db.properties"/><!-- 开启驼峰映射:数据库下划线字段自动映射为Java驼峰属性 --><settings><setting name="mapUnderscoreToCamelCase" value="true"/></settings><!-- 开发环境配置 --><environments default="development"><environment id="development"><transactionManager type="JDBC"></transactionManager><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="com/apesource/mapper/StudentMapper.xml"></mapper></mappers>
</configuration>

二、配置解析与优势说明

1、配置加载流程

这种机制实现了配置与代码的完全分离,数据库参数的变更不会影响核心配置文件。

  1. MyBatis 启动时首先读取 <properties resource="db.properties"/> 配置
  2. 将 db.properties 中的键值对加载到内存中
  3. 在 <dataSource> 配置中通过 ${key} 格式引用对应的值

2、多环境配置技巧

实际开发中,我们通常需要区分开发、测试和生产环境,可通过以下方式实现:

# 创建多个环境的配置文件
db_dev.properties  # 开发环境
db_test.properties # 测试环境
db_prod.properties # 生产环境

切换环境时,只需修改加载的配置文件名称:

<!-- 切换到生产环境 -->
<properties resource="db_prod.properties"/>

3、与驼峰映射的协同作用

配置中同时开启了驼峰映射:

<setting name="mapUnderscoreToCamelCase" value="true"/>

结合 db.properties 的使用,实现了双重优化:

  • 数据库连接参数的集中管理
  • 数据库字段(如 user_name)与 Java 属性(如 userName)的自动映射

两者配合使用,极大提升了开发效率和代码整洁度。

三、最佳实践建议

  1. 敏感信息处理:生产环境中,建议对 db.properties 中的密码进行加密处理
  2. 版本控制忽略:在 .gitignore 中添加 db.properties,避免敏感信息提交到代码仓库
  3. 规范命名:保持 properties 中的键名与 MyBatis 引用的一致性,建议使用 jdbc. 作为前缀
  4. 连接参数优化:在 jdbc.url 中添加必要的参数,如字符编码 characterEncoding=utf8

通过这种配置方式,我们的项目将获得更好的可维护性、更高的安全性和更灵活的环境切换能力。尤其是在团队协作和多环境部署的场景下,db.properties 的优势会体现得淋漓尽致。

http://www.xdnf.cn/news/17330.html

相关文章:

  • RAGFoundry:面向检索增强生成的模块化增强框架
  • 五、RuoYi-Cloud-Plus 前端项目部署以及如何改后端请求地址。
  • 【CTF】PHP反序列化基础知识与解题步骤
  • Java 大视界 -- Java 大数据在智能医疗手术机器人操作数据记录与性能评估中的应用(390)
  • 深入剖析Spring MVC核心原理:从请求到响应的魔法解密
  • Java-线程线程的创建方式
  • 【线性代数】线性方程组与矩阵——(3)线性方程组解的结构
  • kubectl get node k8s-node01 -o yaml | grep taint -B 5 -A 5
  • 电子电气架构 --- 48V车载供电架构
  • 第16届蓝桥杯Scratch选拔赛初级及中级(STEMA)2024年11月24日真题
  • 阿里Qwen-Image本地部署详细指南
  • SAP在越南投资1.75亿美元建设研发中心
  • 多线程(四) --- 线程安全问题
  • JS逆向实战案例之----【通姆】252个webpack模块自吐
  • jQuery 零基础学习第一天
  • 进阶向:Python编写网页爬虫抓取数据
  • PG靶机 - Shiftdel
  • 日语学习-日语知识点小记-构建基础-JLPT-N3阶段(15):文法+单词第5回
  • 99-基于Python的京东手机数据分析及预测系统
  • 母线电压采样芯片的四大类——汽车级选型对比表
  • git查看单个文件的所有修改记录
  • 105-基于Flask的珍爱网相亲数据可视化分析系统
  • ubuntu修改密码
  • SQL 172 未完成试卷数大于1的有效用户
  • 【高等数学】第八章 向量代数与空间解析几何——第四节 空间直线及其方程
  • EPI2ME分析软件测试
  • 数字图像处理基础——opencv库(Python)
  • 我用C++和零拷贝重构了文件服务器,性能飙升3倍,CPU占用降低80%
  • 从“人拉肩扛”到“智能协同”——AGV重构消防智能仓储价值链
  • 记录一次ubuntu20.04 解决gmock not found问题的过程