讨论JAVA操作数据库方式与设计模式应用[1]
By  IT  Jack 发表于 2008-3-4 17:13:00 

  1. 在业务层使用JDBC直接操作数据库-最简单,最直接的操作

  1)数据库url,username,password写死在代码中

  Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();

  String url="jdbc:oracle:thin:@localhost:1521:orcl";

  String user="scott";

  String password="tiger";

  Connection conn= DriverManager.getConnection(url,user,password);

  Statement stmt=conn.createStatement(

  ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

  String sql="select * from test";

  ResultSet rs=stmt.executeQuery(sql);

  2)采用Facade和Command模式,使用DBUtil类封装JDBC操作;

  数据库url,username,password可以放在配置文件中(如xml,properties,ini等)。

  这种方法在小程序中应用较多。

  2.DAO(Data Accessor Object)模式-松耦合的开始

  DAO = data + accessor + domain object

  例如User类-domain object (javabean)

  UserDAO类-accessor ,提供的方法getUser(int id),save(User user)内包含了JDBC操作

  在业务逻辑中使用这两个类来完成数据操作。

  使用Factory模式可以方便不同数据库连接之间的移植。

  3.数据库资源管理模式

  3.1 数据库连接池技术

  资源重用,避免频繁创建,释放连接引起大大量性能开销;

  更快的系统响应速度;

  通过实现JDBC的部分资源对象接口( Connection, Statement, ResultSet ),可以使用Decorator设计模式分别产生三种逻辑资源对象: PooledConnection, PooledStatement和 PooledResultSet。

  一个最简单地数据库连接池实现:

  public class ConnectionPool {

  private static Vector pools;

  private final int POOL_MAXSIZE = 25;

  /**

  * 获取数据库连接

  * 如果当前池中有可用连接,则将池中最后一个返回;若没有,则创建一个新的返回

  */

  public synchronized Connection getConnection() {

  Connection conn = null;

  if (pools == null) {

  pools = new Vector();

  }

  if (pools.isEmpty()) {

  conn = createConnection();

  } else {

  int last_idx = pools.size() - 1;

  conn = (Connection) pools.get(last_idx);

  pools.remove(last_idx);

  }

  return conn;

  }

  /**

  * 将使用完毕的数据库连接放回池中

  * 若池中连接已经超过阈值,则关闭该连接;否则放回池中下次再使用

  */

  public synchronized void releaseConnection(Connection conn) {

  if (pools.size() >= POOL_MAXSIZE)

  try {

  conn.close();

  } catch (SQLException e) {

  // TODO自动生成 catch 块

  e.printStackTrace();

  } else

  pools.add(conn);

  }

  public static Connection createConnection() {

  Connection conn = null;

  try {

  Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();

  String url = "jdbc:oracle:thin:@localhost:1521:orcl";

  String user = "scott";

  String password = "tiger";

  conn = DriverManager.getConnection(url, user, password);

  } catch (InstantiationException e) {

  // TODO自动生成 catch 块

  e.printStackTrace();

 
阅读全文 | 回复(0) | 引用通告 | 编辑
发表评论:

 
站点公告
站点日历
最新日志
最新评论
最新留言
友情链接
站点统计
日志搜索
用户登陆