<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é)合 閱讀(2691) 評(píng)論(5)  編輯  收藏 所屬分類: pattern 、mysql

    評(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)航:
     
    主站蜘蛛池模板: 亚洲人成人77777网站不卡| 婷婷国产偷v国产偷v亚洲| 毛片免费在线观看网站| 深夜福利在线免费观看| 亚洲成AV人片在线观看无码| 99爱在线精品免费观看| 野花视频在线官网免费1| 久久精品7亚洲午夜a| 男男AV纯肉无码免费播放无码 | 亚洲精品视频在线| 国产精品无码免费播放| 好湿好大好紧好爽免费视频| 亚洲国产精品成人精品小说 | 亚洲高清一区二区三区电影| 亚洲中文字幕无码久久精品1 | 四虎影院永久免费观看| 免费无码毛片一区二区APP| 豆国产96在线|亚洲| 亚洲一区二区三区日本久久九| 免费特级黄毛片在线成人观看| 国产午夜精品免费一区二区三区| 亚洲中文字幕乱码AV波多JI| 亚洲色偷拍另类无码专区| 大地资源在线观看免费高清| 国内精品免费在线观看| 精品视频免费在线| 亚洲国产福利精品一区二区| 亚洲日韩国产精品第一页一区| 毛片大全免费观看| 最近新韩国日本免费观看| 成人免费777777被爆出| 亚洲jizzjizz少妇| 亚洲另类视频在线观看| 亚洲AV天天做在线观看| 亚洲中久无码不卡永久在线观看| 四虎永久在线精品免费网址 | 在线免费观看视频你懂的| 久久久久久久久久国产精品免费 | 日韩在线观看视频免费| 亚洲精品国产精品国自产网站| 亚洲成色在线影院|