对于JDBC桥接和写ConnectionManager来连接数据库,我们已经相当熟悉了,而且采用连接池前面也讲过了,那么,当我们的数据库要升级或者是改变密码等变动时,采用前面的方式不是很麻烦吗?
今天介绍一下用配置文件来获取数据库连接对象:
先建一个后缀为.properties的文件,里面的内容就是连接数据库的一下参数,以我的电脑sqlserver 2005为例,文件内容为——
driver=com.microsoft.jdbc.sqlserver.SQLServerDriver
url=jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=**
user=**
password=**
上面的内容就不用介绍了,行家应该都能够看懂。
既然是文件,那么就要使用文件的读写了,大家应该没有忘记是io来管理文件读写的吧。为了读取.properties文件,就建一个文件读取类,不过要继承Properties类。类中读取的代码如下:
import java.util.Properties;
import java.io.*;
public class Env extends Properties {
private static Env instance;
public static Env getInstance() {
if (instance != null) {
return instance;
} else {
makeInstance();
return instance;
}
}
public static void setInstance(Env instance) {
Env.instance = instance;
}
// synchronized保证在同一时间内只能别一个人调用!(同步方法的意思)
private static synchronized void makeInstance() {
if (instance == null) {
instance = new Env();
}
}
private Env() {
InputStream is = getClass().getResourceAsStream("/db.properties");
try {
load(is);
} catch (Exception e) {
System.out.println("错误:没有读取属性文件," + "请确认db.properties文件是否存在!");
}
}
}
获得了文件内容,就是连接数据库了,用一个单独的类来管理连接如下:
public class ConnPropertiesManager {
public static synchronized Connection getConnection()
throws DBAccessException {
Connection conn = null;
String driverClassName = Env.getInstance().getProperty("driver");
String url = Env.getInstance().getProperty("url");
String user = Env.getInstance().getProperty("user");
String password = Env.getInstance().getProperty("password");
try {
Class.forName(driverClassName);
conn = DriverManager.getConnection(url, user, password);
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
这样就获得了数据库连接,想在哪里使用就在哪里使用,而且,最大的好处就是如果你的数据库信息改变了,也只要打开配置文件来修改就好了,不用去改你的项目啊。避免了很多问题!
好好看吧。希望对大家有所帮助,呵呵!