在开发中,某程序有时需要连接不同类型的数据库、以不同的身份连接数据库,那就意味着连接数据库的4个参数(驱动、URL、用户名、密码)时常都需要修改,难道每变动一次,都要去改一下连接数据库的代码吗?
Table of Contents
针对这个问题的解决方案之一就是:配置文件!
- 把随时变动的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;
}
}