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

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

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

    數(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;
    /*
     * 外觀模式的主要用途就是為子系統(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é)合 閱讀(2689) 評(píng)論(5)  編輯  收藏 所屬分類: 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類是個(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è)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 久久久久久亚洲AV无码专区| 亚洲熟妇无码八AV在线播放| 亚洲日本国产精华液| 最近免费视频中文字幕大全| 亚洲视频一区二区在线观看| 57pao国产成视频免费播放 | 猫咪免费人成在线网站| 好爽好紧好大的免费视频国产| 亚洲精品自偷自拍无码| 四虎1515hm免费国产| 亚洲天堂免费在线视频| 亚洲成色WWW久久网站| 99久热只有精品视频免费看 | 亚洲成av人片在线观看无码不卡| a级毛片免费在线观看| 亚洲AV无码乱码国产麻豆| 99热在线观看免费| 亚洲国产精品久久久久秋霞影院| 青春禁区视频在线观看直播免费| 亚洲精品无码aⅴ中文字幕蜜桃| 无码专区一va亚洲v专区在线| 两个人看www免费视频| 亚洲黄色高清视频| 无码人妻精品一二三区免费| 色多多A级毛片免费看| 亚洲国产精品无码成人片久久 | 日韩特黄特色大片免费视频| 曰韩无码AV片免费播放不卡| 久久久久无码精品亚洲日韩| 9久9久女女免费精品视频在线观看| 亚洲av最新在线观看网址| 亚洲色精品aⅴ一区区三区| 又大又硬又爽又粗又快的视频免费| 亚洲另类无码专区首页| 老司机亚洲精品影视www| 4虎1515hh永久免费| 国产成人亚洲精品91专区高清 | 亚洲大成色www永久网站| 在线免费观看一级片| 成av免费大片黄在线观看| 亚洲影视自拍揄拍愉拍|