<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    hengheng123456789

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      297 Posts :: 68 Stories :: 144 Comments :: 0 Trackbacks

    Facade模式的定義 : 為子系統中的一組接口提供一個一致的界面.

    Facade一個典型應用就是數據庫JDBC的應用,如下例對數據庫的操作:

    public class DBCompare {

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

    上例是Jsp中最通常的對數據庫操作辦法.

    在應用中,經常需要對數據庫操作,每次都寫上述一段代碼肯定比較麻煩,需要將其中不變的部分提煉出來,做成一個接口,這就引入了facade外觀對象.如果以后我們更換Class.forName中的<driver>也非常方便,比如從Mysql數據庫換到Oracle數據庫,只要更換facade接口中的driver就可以.

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

    public class DBCompare {

      String sql = "SELECT * FROM <table> WHERE <column name> = ?";  

      try {
         Mysql msql=new mysql(sql);
         prep.setString( 1, "<column value>" );
         rset = prep.executeQuery();
         if( rset.next() ) {
            System.out.println( rset.getString( "<column name" ) );
         }
      } catch( SException e ) {
         e.printStackTrace();
      } finally {
         mysql.close();
         mysql=null;
      }
    }

    可見非常簡單,所有程序對數據庫訪問都是使用改接口,降低系統的復雜性,增加了靈活性.

    如果我們要使用連接池,也只要針對facade接口修改就可以.

    ?

    由上圖可以看出, facade實際上是個理順系統間關系,降低系統間耦合度的一個常用的辦法,也許你已經不知不覺在使用,盡管不知道它就是facade.

    posted on 2007-03-16 17:42 哼哼 閱讀(254) 評論(0)  編輯  收藏 所屬分類: Design Pattern
    主站蜘蛛池模板: 国产精品黄页免费高清在线观看| 一级毛片aaaaaa免费看| 亚洲精品午夜无码专区| 久久爰www免费人成| 亚洲中文字幕AV在天堂| 亚洲第一网站男人都懂| 中文字幕无码免费久久| 亚洲妇女熟BBW| 亚洲精品自产拍在线观看| 国产h视频在线观看免费| 一级毛片一级毛片免费毛片| 亚洲精品不卡视频| 亚洲成a人片在线观看国产| 日韩人妻一区二区三区免费| 国产成人亚洲精品无码AV大片| 亚洲视频免费在线观看| 免费一级毛片在播放视频| 91短视频在线免费观看| 日韩精品视频在线观看免费| 亚洲国产日韩女人aaaaaa毛片在线| 亚洲成人高清在线| 永久免费av无码不卡在线观看| 一级做a爱片特黄在线观看免费看| 亚洲依依成人精品| 亚洲情XO亚洲色XO无码| 免费a级毛片永久免费| av无码久久久久不卡免费网站| 亚洲免费日韩无码系列| 亚洲AV性色在线观看| 亚洲日韩中文字幕| 亚洲精品白浆高清久久久久久| 日本高清免费不卡在线| 亚洲一级免费视频| 国产婷婷成人久久Av免费高清| 国产在亚洲线视频观看| 亚洲精品无码久久久久APP | 无码国产精品一区二区免费vr| 疯狂做受xxxx高潮视频免费| 亚洲videos| 亚洲伊人久久大香线蕉| 亚洲今日精彩视频|