數(shù)據(jù)加載中……
          Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫(kù)JDBC的應(yīng)用
          Facade模式的定義: 為子系統(tǒng)中的一組接口提供一個(gè)一致的界面.Facade一個(gè)典型應(yīng)用就是數(shù)據(jù)庫(kù)JDBC的應(yīng)用,如下例對(duì)數(shù)據(jù)庫(kù)的操作:
          說(shuō)明:這是在網(wǎng)上的一篇文章中看到的列子,上面沒(méi)有寫(xiě)全,我在這里補(bǔ)上了,沒(méi)有用到接口。

          package com.pattern.structural.facade;

          import java.sql.Connection;
          import java.sql.DriverManager;
          import java.sql.PreparedStatement;
          import java.sql.ResultSet;
          import java.sql.SQLException;
          /*
           * 外觀(guān)模式的主要用途就是為子系統(tǒng)的復(fù)雜處理過(guò)程提供方便的調(diào)用方法,
           * 使得子系統(tǒng)更加容易被使用。
           * Facade對(duì)象通常屬于Singleton模式。
          */
          public class Mysql {
             
              private static Connection conn=null;
              private static PreparedStatement prep=null;

              public Mysql(String sql) {
                  try {
                      Class.forName("com.mysql.jdbc.Driver").newInstance();
                      conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test","root","");
                      prep = conn.prepareStatement(sql);
                  } catch (Exception e) {
                      e.printStackTrace();
                  }
              }

              public void setString(int index, String parString) {
                  try {
                      prep.setString(index, parString);
                  } catch (SQLException e) {
                      e.printStackTrace();
                  }
              }

              public ResultSet executeQuery() {
                  try {
                      return prep.executeQuery();
                  } catch (SQLException e) {
                      e.printStackTrace();
                      return null;
                  }
              }

              public void close() {
                  try {
                      conn.close();
                      prep.close();
                  } catch (SQLException e) {
                      e.printStackTrace();
                  }
              }
          }


          package com.pattern.structural.facade;

          import java.sql.Connection;
          import java.sql.DriverManager;
          import java.sql.PreparedStatement;
          import java.sql.ResultSet;

          public class DBCompare {

              public void getResultSet(String sql) {
          //        String sql = "SELECT * FROM bulletin WHERE id = ?";
                  Mysql mysql = new Mysql(sql);
                  try {
                      mysql.setString(1, "4");
                      ResultSet rset = mysql.executeQuery();
                      while (rset.next()) {
                          System.out.println(rset.getString("id"));
                      }
                  } catch (Exception e) {
                      e.printStackTrace();
                  } finally {
                      mysql.close();
                      mysql = null;
                  }
              }
          }


          package com.pattern.structural.facade;

          import java.sql.ResultSet;

          public class FacadeTest {

              public static void main(String[] args) {
                 
                  Mysql mysql = new Mysql("SELECT * FROM bulletin");
                  try {
                      ResultSet rset = mysql.executeQuery();
                      while (rset.next()) {
                          System.out.println(rset.getString("id"));
                      }
                  } catch (Exception e) {
                      e.printStackTrace();
                  } finally {
                      mysql.close();
                      mysql = null;
                  }
                 
              }

          }

          posted on 2008-02-28 15:27 java flex 結(jié)合 閱讀(2695) 評(píng)論(5)  編輯  收藏 所屬分類(lèi): patternmysql

          評(píng)論

          # re: Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫(kù)JDBC的應(yīng)用 2008-02-29 10:38 香草的天空

          你這個(gè)其實(shí)叫Dao

          不素Facade

          # re: Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫(kù)JDBC的應(yīng)用 2008-03-02 14:44 xifu

          Facade的本意是為不同的操作通過(guò)封裝提供統(tǒng)一的、一致的操作方法

          # re: Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫(kù)JDBC的應(yīng)用 2008-05-22 12:54  .

          什么跟什么 啊。。。。。。。。。。。。。。。

          # re: Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫(kù)JDBC的應(yīng)用 2010-06-17 10:09 facade

          你不懂

          # re: Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫(kù)JDBC的應(yīng)用 2012-06-07 16:06 kensunhu

          認(rèn)為Mysql類(lèi)是個(gè)facade,因?yàn)榉隙x:“Provide a unified interface to a set of interfaces in a subsystem. Facade Pattern defines a higher-level interface that makes the subsystem easier to use.”

          只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 博乐市| 仁布县| 澄城县| 青川县| 富裕县| 武陟县| 布尔津县| 沂源县| 遂平县| 图们市| 泸水县| 桐柏县| 宝山区| 平定县| 黔西县| 五河县| 吐鲁番市| 沙洋县| 封开县| 卢龙县| 鄂托克前旗| 左贡县| 肃北| 津南区| 增城市| 屏山县| 潼南县| 宁河县| 那曲县| 汉中市| 射洪县| 马尔康县| 柳州市| 濮阳县| 锦州市| 深水埗区| 丹棱县| 济源市| 四子王旗| 聂拉木县| 台江县|