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

    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ù)雜處理過程提供方便的調(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ù)庫JDBC的應(yīng)用 2008-02-29 10:38 香草的天空

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

    不素Facade

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

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

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

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

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

    你不懂

    # re: Facade模式的一個(gè)典型應(yīng)用--數(shù)據(jù)庫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免费放dvd| 亚洲国产精品自在在线观看 | 亚洲国产中文在线视频| 在线看片v免费观看视频777| 亚洲人成777在线播放| 免费看美女被靠到爽的视频| 国产亚洲综合一区二区三区| 亚洲国产精品日韩| 黄网站免费在线观看| 亚洲精品在线播放| 免费观看的毛片手机视频| 在线播放国产不卡免费视频| 国产亚洲综合久久系列| 五月亭亭免费高清在线| 亚洲成av人片在www鸭子| 在线观看亚洲精品福利片| 99精品视频在线免费观看 | 国产精品亚洲综合天堂夜夜| 亚洲第一区精品日韩在线播放| 国产麻豆成人传媒免费观看| 亚洲精品成人网站在线播放| 在线观看免费亚洲| 成全动漫视频在线观看免费高清版下载| 亚洲高清无在码在线电影不卡| 精品国产精品久久一区免费式| 两性色午夜视频免费播放| 精品亚洲AV无码一区二区三区| 又大又黄又粗又爽的免费视频| 今天免费中文字幕视频| 亚洲欧美第一成人网站7777| 国产亚洲综合一区柠檬导航| 成人免费毛片内射美女APP| 久久免费观看视频| 亚洲一卡2卡3卡4卡5卡6卡|