用配置文件处理数据库连接

对于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; 
} 

 这样就获得了数据库连接,想在哪里使用就在哪里使用,而且,最大的好处就是如果你的数据库信息改变了,也只要打开配置文件来修改就好了,不用去改你的项目啊。避免了很多问题!
好好看吧。希望对大家有所帮助,呵呵!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值