Java设计模式(11)外观模式(Facade模式)

外观模式(Facade)的定义:为子系统中的一组接口提供一个一致的界面。

Facade一个典型应用就是数据库JDBC的应用,如下例对数据库的操作:

public class DBCompare {
 Connection conn = null;
 PreparedStatement prep = null;
 ResultSet rset = null;
 try {
  Class.forName( "" ).newInstance();
  conn = DriverManager.getConnection( "" );
    
  String sql = "SELECT * FROM  WHERE  = ?";
  prep = conn.prepareStatement( sql );
     prep.setString( 1, "" );
  rset = prep.executeQuery();
  if( rset.next() ) {
    System.out.println( rset.getString( " ) );
  }
 } catch( SException e ) {
  e.printStackTrace();
 } finally {
  rset.close();
  prep.close();
  conn.close();
 }
} 
     
    
   

上例是Jsp中最通常的对数据库操作办法。

在应用中,经常需要对数据库操作,每次都写上述一段代码肯定比较麻烦,需要将其中不变的部分提炼出来,做成一个接口,这就引入了facade外观对象。如果以后我们更换Class.forName中的也非常方便,比如从Mysql数据库换到Oracle数据库,只要更换facade接口中的driver就可以。

我们做成了一个Facade接口,使用该接口,上例中的程序就可以更改如下:

public class DBCompare {
 String sql = "SELECT * FROM 
WHERE = ?";    try {   Mysql msql=new mysql(sql);   prep.setString( 1, "" );   rset = prep.executeQuery();   if( rset.next() ) {    System.out.println( rset.getString( " ) );   }  } catch( SException e ) {   e.printStackTrace();  } finally {   mysql.close();   mysql=null;  } }

可见非常简单,所有程序对数据库访问都是使用改接口,降低系统的复杂性,增加了灵活性。

如果我们要使用连接池,也只要针对facade接口修改就可以。

Java设计模式(11)外观模式(Facade模式)_第1张图片

由上图可以看出,facade实际上是个理顺系统间关系,降低系统间耦合度的一个常用的办法,也许你已经不知不觉在使用,尽管不知道它就是facade。

系列文章:

Java设计模式(1)工厂模式(Factory模式)

Java设计模式(2)单态模式(Singleton模式)

Java设计模式(3)建造者模式(Builder模式)

Java设计模式(4)原型模式(Prototype模式)

Java设计模式(5)共享模式/享元模式(Flyweight模式)

Java设计模式(6)桥模式(Bridge模式)

Java设计模式(7)装饰模式(Decorator模式)

Java设计模式(8)组合模式(Composite模式)

Java设计模式(9)适配器模式(Adapter模式)

Java设计模式(10)代理模式(Proxy模式)

Java设计模式(11)外观模式(Facade模式)

Java设计模式(12)迭代模式(Iterator模式)

Java设计模式(13)模板模式(Template模式)

Java设计模式(14)责任链模式(Chain of Responsibility模式)

Java设计模式(15)备忘录模式(Memento模式)

Java设计模式(16)中介模式(Mediator模式)

Java设计模式(17)解释器模式(Interpreter模式)

Java设计模式(18)策略模式(Strategy模式)

Java设计模式(19)状态模式(State模式)

Java设计模式(20)观察者模式(Observer模式)

Java设计模式(21)访问模式(Visitor者模式)

Java设计模式(22)命令模式(Command模式)

你可能感兴趣的:(java,设计模式,数据库)