我看过很多数据库连接的代码,大部分都存在问题,有的甚至完全不可用,这里给出一个数据库连接工厂,给出了jdbc1和jdbc2的实现,仅供参考!
public class ConnectionFactory_JDBC1{ private static String url="jdbc:oracle:thin:@218.12.7.35:1521:myorcl"; private static String user="developer"; private static String password="developer"; static{ try{ Class.forName("oracle.jdbc.driver.OracleDriver"); } catch(ClassNotFoundException e){ throw new RuntimeException("无法加载数据库驱动!"); } } static Connection getConnection() throws SQLException { return DriverManager.getConnection(url,user,password); } public static void closeConnection(Connection conn){ if (conn != null) { try { conn.close(); } catch (SQLException e) { //没有必要处理 } } } } 上面连接的是oracle数据库,当然这里用户名和密码以及url你也可以通过配置文件获得,虽然只有短短的几行 代码,对于新手,要完全理解也不是很容易的事,如果可能尽量使用JDBC2方法。
public class ConnectionFactory_JDBC2{ private static String dbName="jdbc/mydb"; private static DataSource ds; static{ try{ Context ctx=new InitialContext(); ds = (DataSource)ctx.lookup(dbName); } catch(NamingException e){ throw new RuntimeException("无法获得数据源!"); } } public static Connection getConnection() throws SQLException { return ds.getConnection(); } public static void closeConnection(Connection conn){ if (conn != null) { try { conn.close(); } catch (SQLException e) { //没有必要处理 } } } }
上面只是提供一个连接工厂,你必须自己关闭数据库连接,这里的closeConnection方法先判断是否为空是必要的。你也许觉得可以这样写更简洁: try{ conn.close();} catch(Exception e) {}; //同时处理了NullPointerExceptio 个人认为这样写不好,当然这样也没有错。

|