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

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

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

    如鵬網 大學生計算機學習社區

    CowNew開源團隊

    http://www.cownew.com 郵件請聯系 about521 at 163.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      363 隨筆 :: 2 文章 :: 808 評論 :: 0 Trackbacks

    工廠方法模式
       
    以可移植的、可擴展的方式來生成流水號EJB應用中的一個難點。 現在比較成熟的流水號生成策略有全局唯一標識(即UUID)和使用數據庫內置流水號生成策略。全局唯一標識有單件模式、根據網絡標識(Mac地址+IPJVM唯一對象標識)等策略。不同的數據庫也有不同的流水號生成策略:例如Oracle采用內置流水號產生機制,SQL Server則采用Identity機制。這給我們帶來方便的同時也使得應用程序在不同系統之間移植變得很麻煩。我采用工廠方法模式解決這個問題。
      
    結構圖


    我們首先定義一個基類接口,它定義了各種唯一序列生成器的共同的方法。
    abstract public interface SequenceCreator {
      abstract public String getSequenceId(String aId);
      abstract public Integer getSequenceAsInt(String aId);
    }
     
    兩個函數的參數aId是不同流水號生成標識。getSequenceId是產生以字符串形式返回的流水號,getSequenceAsInt是以整形形式返回流水號。為了防止無謂的重復,下面的實例中我們將只寫各個方法的getSequenceId實現。

    1)我們首先看SQLSequenceCreator的實現代碼

        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

        Connection con = java.sql.DriverManager.getConnection("jdbc:odbc:DNSEJB");

        CallableStatement cs = con.prepareCall("{call SetIndex(?,?,?)}");

        cs.registerOutParameter(2,Types.VARCHAR);

        cs.setString(1,aId);

        cs.setInt(3,10);

        cs.executeUpdate();

        String str= cs.getString(2);

        return str.substring(aId.length(), str.length());

    我們是調用我們自定義的存儲過程來生成流水號的,存儲過程的代碼請參看代碼。

    2Oracle的實現代碼

    String strSQL = "select " + sequence_name + ".nextval from DUAL";

        Statement  stmt = conn.createStatement();

        ResultSet rs = stmt.executeQuery(strSQL);

        rs.next();

    return rs.getString(1);

    Oracle對流水號生成提供了比較好的支持,而且Oracle的生成策略也比SQLServer更高效,消耗更少的資源,資源鎖定情況也比SQLServer少。

    3

    UUID的實現代碼

    InetAddress inet = InetAddress .getLocalHost();

    Byte[] bytes = inet.getAddress();

    String hexInetAddress = hexFormat(getInt(bytes),8);

    String thisHashCode=hexFormat(System.identityHashCode(this),8);

    MideValue = hexInetAddress+thisHashCode;

    Seeder = new SecureRandom();

    In node = seeder.nextInt();

    Long timeNow = System.currentTimeMillis();

    Int timeLow = (int)timeNow&oxFFFFFFF;

    Int  node = seeder.nextInt();

    Return (hexFormat(timeLow,8)+mid+hexFormat(node,8));

        UUID是一個基于字符串的主鍵,他有一下字符串組合而成:利用System.currentTimeMillis()精確道毫秒的唯一、IP地址的十六進制標識、利用System.identityHashCode(this)得到的一個JVM內部的唯一地址標識和利用隨機數生成器生成隨機數。

     

    還有很多不同的流水號生成策略,我們不準備一一羅列。我們的主要問題是要解決在采用不同的序列生成策略時將代碼的修改減到最小。

    我們定義的SequenceCreator 類定義了所有流水號生成策略公共的方法,并且把這些方法定義為虛方法,在不同的流水號生成策略代碼中只要覆蓋這些方法即可。序列號生成器工廠類SequenceCreatorFactory getSquenceCreator()并不返回具體的流水號生成類,而是返回SequenceCreator,這樣當采用不同策略時只要修改getSquenceCreator方法即可。

    posted on 2006-03-11 00:11 CowNew開源團隊 閱讀(3019) 評論(1)  編輯  收藏

    評論

    # re: 工廠方法模式解決流水號生成問題 2006-03-11 11:37 Parker
    org.springframework.jdbc.support.incrementer.DataFieldMaxValueIncrementer  回復  更多評論
      


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 一级毛片免费毛片一级毛片免费 | 亚洲国产片在线观看| 国产精品九九久久免费视频| 国产公开免费人成视频| 国产亚洲精品美女| 亚洲?v无码国产在丝袜线观看| 女bbbbxxxx另类亚洲| 亚洲成年人啊啊aa在线观看| 免费无码专区毛片高潮喷水| 亚洲国产中文v高清在线观看| 久久www免费人成精品香蕉| 亚洲精品中文字幕无码蜜桃| 免费在线黄色电影| 亚洲综合激情另类小说区| 131美女爱做免费毛片| 精品久久亚洲中文无码| 暖暖日本免费在线视频| 欧亚一级毛片免费看| 亚洲精品无码久久久久| 91视频免费网址| 亚洲最大av资源站无码av网址| 永久黄网站色视频免费直播| 成年网在线观看免费观看网址| 亚洲精品无码久久一线| 无码乱肉视频免费大全合集| 亚洲乱码中文字幕在线| 亚洲一区日韩高清中文字幕亚洲 | 免费观看美女裸体网站| 国产精品自拍亚洲| 好看的电影网站亚洲一区| 日韩在线播放全免费| 国产av无码专区亚洲av毛片搜| 亚洲人成色777777在线观看| 又大又硬又爽又粗又快的视频免费| 亚洲色少妇熟女11p| 国产成人精品久久亚洲| 免费v片在线观看视频网站| 337P日本欧洲亚洲大胆艺术图| 国产亚洲精品a在线无码| 性做久久久久久久免费看| 国产va免费精品|