<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)航:
     
    主站蜘蛛池模板: 日本不卡视频免费| 成年美女黄网站色大免费视频| 四虎亚洲国产成人久久精品| 青草久久精品亚洲综合专区| 热久久精品免费视频| 亚洲国产精品无码久久98| 日韩免费电影在线观看| 亚洲av色香蕉一区二区三区 | 日本亚洲欧美色视频在线播放| 久久笫一福利免费导航| 亚洲成AV人片在WWW| 在线观看亚洲免费| 人碰人碰人成人免费视频| 亚洲综合色婷婷七月丁香| 免费人成网站在线观看不卡| 亚洲一区二区在线免费观看| 成人免费视频网站www| 亚洲色偷偷色噜噜狠狠99| 又黄又爽无遮挡免费视频| 黄色视频在线免费观看| 亚洲视频在线观看一区| 在线精品一卡乱码免费| 亚洲av无码一区二区三区天堂| 四虎影库久免费视频| 99re6在线精品免费观看| 亚洲精品国产第1页| 男女交性永久免费视频播放| 免费无码又爽又黄又刺激网站| 亚洲精品成人片在线观看精品字幕| 日韩免费无码视频一区二区三区| 亚洲免费一级视频| 亚洲国产成人久久综合碰| 无码精品国产一区二区三区免费| 免费人成激情视频在线观看冫| 亚洲AV无码精品无码麻豆| 一区二区三区免费在线视频| 亚洲精品综合一二三区在线| 影音先锋在线免费观看| 最近的2019免费中文字幕| 亚洲国产av美女网站| 亚洲人成影院在线观看|