【JDBC】使用properties管理连接数据库的URL、用户名和密码

在开发中,某程序有时需要连接不同类型的数据库、以不同的身份连接数据库,那就意味着连接数据库的4个参数(驱动、URL、用户名、密码)时常都需要修改,难道每变动一次,都要去改一下连接数据库的代码吗?


Table of Contents

第一个Properties程序

管理数据库的连接参数


针对这个问题的解决方案之一就是:配置文件!

  • 把随时变动的4个连接参数(驱动、URL、用户名、密码)放在配置文件中,每当程序需要连接数据库时,就读取这个配置文件以获取连接参数。
  • 这样一来,每次进行不同的连接,只需要修改配置文件中的参数即可,而不需要修改程序的具体代码。
  • 这样方便后期维护,程序如果需要更换数据库,只需要修改配置文件即可。

  • Java提供配置文件支持的类是java.util.Properties

对properties文件的要求:

1.   文件位置:任意,建议src下,否则会出现很多问题!

2.   文件名称:任意,扩展名为properties

3.   文件内容:一行一组数据,格式是“key=value”.

key命名自定义,如果是多个单词,习惯使用点分隔。例如:jdbc.driver

value值不支持中文,如果需要使用非英文字符,将进行unicode转换。

通过以下两个实例,学习Properties的用法

第一个Properties程序

在项目所在目录下创建一个文本文件,命名为:MysqlConfig.properities(注:其他命名也可以,只要你喜欢),并键入以下内容:

driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mydb
username=root
password=kyle

创建一个Java类,操作其中的内容:

Properities连接示例
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;

public class UseProperitesManageConfig {
	public static void main(String[] args) {
		//使用类的加载器
		InputStream in = UseProperitesManageConfig.class.getClassLoader().getResourceAsStream("MysqlConfig.properities");
		//System.out.println(in); //表明以正确读取配置文件:java.io.BufferedInputStream@5577140b
		Properties pro = new Properties();
		
		try {
			pro.load(in);
		} catch (IOException e) {
			e.printStackTrace();
		}
		
		//获取集合中的键值对
		//注意,要加载MySQL驱动
		String driverClass=pro.getProperty("driverClass");
		String url = pro.getProperty("url");
		String username = pro.getProperty("username");
		String password = pro.getProperty("password");
		
		try {
			Class.forName(driverClass);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		
		Connection con = null;
		try {
			con = DriverManager.getConnection(url, username, password);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		System.out.println(con); //表明与数据库链接成功:com.mysql.jdbc.JDBC4Connection@4923ab24
	}
}

管理数据库的连接参数

仔细阅读下列代码,理解用法:

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Properties;

public class UseProperitiesManageConnect {
	private static Connection con ;
	private static String driverClass;
	private static String url;
	private static String username;
	private static String password;
	
	static{
		try{
			readConfig();
			Class.forName(driverClass);
			con = DriverManager.getConnection(url, username, password);
		}catch(Exception ex){
			throw new RuntimeException("数据库连接失败");
		}
	}
	
	private static void readConfig() {
		InputStream in = UseProperitiesManageConnect.class.getClassLoader().getResourceAsStream("MysqlConfig.properties");
		 Properties pro = new Properties();
		 try {
			pro.load(in);
		} catch (IOException e) {
			e.printStackTrace();
		}
		 driverClass=pro.getProperty("driverClass");
		 url = pro.getProperty("url");
		 username = pro.getProperty("username");
		 password = pro.getProperty("password");
	}
	
	public static Connection getConnection() {
		return con;
	}
}

 

### Spring Boot 整合 MyBatis 时找不到数据库的原因分析 在 Spring Boot 中整合 MyBatis 并配置数据库连接时,如果遇到无法找到数据库的情况,可能是由于以下几个原因引起的: #### 1. **数据源配置错误** 如果 `application.properties` 或 `application.yml` 文件中的数据源配置项填写错误,则可能导致程序无法正确连接到目标数据库。常见的错误包括但不限于: - 数据库 URL 错误(例如拼写错误或端口号不对)[^2]。 - 用户名密码错误。 正确的数据源配置应类似于以下形式: ```properties spring.datasource.url=jdbc:mysql://localhost:3306/your_database_name?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` #### 2. **依赖版本冲突** 如果项目中引入的 MyBatis Spring Boot 的版本不兼容,可能会导致初始化失败或者无法正常加载数据库资源。建议检查项目的 `pom.xml` 文件,确保使用的依赖版本匹配。例如: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.3.0</version> </dependency> ``` #### 3. **未启用 Mapper 接口扫描** 如果没有正确配置 `@MapperScan` 注解来指定 Mapper 接口所在的包路径,MyBatis 将无法识别这些接口,从而引发异常。可以通过以下方式解决此问题[^3]: ```java @SpringBootApplication @MapperScan("com.example.mapper") // 替换为实际的 mapper 路径 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` #### 4. **数据库服务不可用** 当本地开发环境下的 MySQL 或其他数据库服务未启动时,也会报出类似的 “找不到数据库” 错误。可以尝试通过命令行或其他工具手动测试数据库连通性,确认其状态是否正常运行。 #### 5. **IDEA 缺乏 SQL 提示支持** 若开发者希望获得更友好的编码体验,在 IDEA 上完成相应设置后能够享受智能补全功能来的便利。具体做法可参照文档说明调整插件选项以便增强用户体验效果[^4]。 --- ### 解决方案总结 针对上述可能存在的各类状况逐一排查即可定位根本所在;同时注意保持各组件间良好的协作关系以减少不必要的麻烦发生几率。 ```java // 示例代码片段展示如何定义一个简单的 DAO 层类 public interface UserMapper extends BaseMapper<UserEntity> {} ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值