我看过很多数据库连接的代码,大部分都存在问题,有的甚至完全不可用,这里给出一个数据库连接工厂,给出了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 个人认为这样写不好,当然这样也没有错。 
   
 
  |