亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dbconnectionmanager.java

?? 本系統是用java開發的一個新聞發布系統
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package com.ntsky.pool;

import java.io.*;
import java.sql.*;
import java.util.*;

import com.ntsky.common.*;

/**
 * <p>Title: NTsky新聞發布v1.0正式版</p>
 * <p>Description: 數據庫連接池</p>
 * <p>Copyright: Copyright (c) 2003</p>
 * <p>Company: NTsky</p>
 * @authory 姚君林
 * @version 1.0
 */

public class DBConnectionManager {
    static private DBConnectionManager instance; //唯一實例的引用
    static private int clients; //客戶端的連接數目
    private Vector drivers = new Vector();
    private Hashtable pools = new Hashtable(); //創建一個Hashtable對象

    class DBConnectionPool { //定義一個DBConnectionPool類[如果DBConnectionManager要訪問DBConnectionPool必須創建DBConnectionPool的對象]

        private int checkedOut; //判斷是否還有可用的連接
        private Vector freeConnections = new Vector();//創建一個freeConnections的數組
        private int maxConn; //最大連接數
        private String name; //數據庫連接池名
        private String user; //訪問數據庫用戶名
        private String password; //訪問數據庫密碼
        private String URL; //數據庫地址
        private PrintWriter log; //日志
        /**
         * 配置文件各項參數
         * @param name
         * @param url
         * @param user
         * @param password
         * @param maxConn
         */
        public DBConnectionPool(String name, String url, String user,
                                String password, int maxConn) {
            /**
             *配置文件
             */
            this.name = name; //poolname 連接池名
            this.URL = url; //地址
            this.user = user; //用戶名
            this.password = password; //密碼
            this.maxConn = maxConn; //最大的連接數
            //寫日志
            this.log = new PrintWriter(System.err);
            Debug.writeLog("poolname" + this.name); //7、"poolname" + Connection
            Debug.writeLog("URL: " + this.URL); //8、jdbc:mysql://127.0.0.1:3306/nt
            Debug.writeLog("user: " + this.user); //9、user: skyyjl
            Debug.writeLog("password: " + this.password); //10、password: abc
            Debug.writeLog("maxConn: " + this.maxConn); //11、maxConn: 100
        }

        /**
         * 把空閑的連接登記到連接池由的freeConnection()方法實現
         * 它的參數為返回給連接池的連接對象。該對象被加入到freeConnections向量的末尾,然后減少已使用連接計數。
         * 調用notifyAll()是為了通知其它正在等待可用連接的線程。
         * @param Conn
         */
        public synchronized void freeConnection(Connection Conn) {
            freeConnections.addElement(Conn);
            checkedOut--;
            notifyAll();
        }

        /**
         * 如連接池中存在可用連接,則直接返回,否則創建新的連接并返回。
         * 如果沒有可用連接且已有連接總數等于最大限制數,第一個方法將直接返回null,
         * 而第二個方法將等待直到有可用連接為止
         * 所有的可用連接對象均登記在名為freeConnections的向量(Vector)中。
         * 如果向量中有多于一個的連接,getConnection()總是選取第一個。
         * 由于新的可用連接總是從尾部加入向量,從而使得數據庫連接由于長時間閑置而被關閉的風險減低到最小程度。
         *
         * @return Connection
         */
        public synchronized Connection getConnection() {
            Connection con = null;
            if (freeConnections.size() > 0) { //獲取向量中第一個可用連接
                con = (Connection) freeConnections.firstElement(); //創建第一個connection,并用設置為Connection
                freeConnections.removeElementAt(0);
                try {
                    /**
                     * 第一個getConnection()在返回可用連接給客戶程序之前,調用了isClosed()方法驗證連接仍舊有效。
                     * 如果該連接被關閉或觸發異常,getConnection()遞歸地調用自己以嘗試獲取另外的可用連接。
                     */
                    if (con.isClosed()) { //判斷連接是否關閉
                        Debug.writeLog("從連接池" + name + "刪除一個無效連接");
                        con = getConnection(); //遞歸調用自己,嘗試再次獲取可用連接
                    }
                }
                catch (SQLException e) {
                    Debug.writeLog("從連接池" + name + "刪除一個無效連接"); // 遞歸調用自己,嘗試再次獲取可用連接
                    con = getConnection();
                }
            }
            /**
             * 如果在向量freeConnections中不存在任何可用連接,getConnection()方法檢查是否已經指定最大連接數限制。
             * 如已經指定,則檢查當前連接數是否已經到達極限。此處maxConn為0表示沒有限制。
             * 如果沒有指定最大連接數限制或當前連接數小于該值,該方法嘗試創建新的連接。
             * 如創建成功,則增加已使用連接的計數(checkout)并返回,否則返回空值。
             */
            else if (maxConn == 0 || checkedOut < maxConn) {
                con = newConnection(); //創建連接(數量由maxConn決定)
            }
            if (con != null) { //如果conn(連接數)不為空,判斷就加
                checkedOut++;
            }
            if (con == null) { //如果為空就將con為空寫入日志
                Debug.writeLog(
                    "DBConnectionPool getConnection(), The Returned Con is null");
            }
            return con; //返回連接
        }

        /**
         * 用一個以毫秒為單位的時間參數,該參數表示客戶程序能夠等待的最長時間。
         * 建立連接的具體操作仍舊由第一個getConnection()方法實現。
         * 參見前一個getConnection()方法.
         * @param timeout 以毫秒計的等待時間限制
         */
        public synchronized Connection getConnection(long timeout) {
            long startTime = new java.util.Date().getTime(); //連接的初始時間
            Connection con;
            /**
             * 在while循環中嘗試獲得一個連接。如果失敗,則以給定的時間值為參數調用wait()。
             * wait()的返回可能是由于其它線程調用notify()或notifyAll(),也可能是由于預定時間已到。
             * 為找出wait()返回的真正原因,程序用當前時間減開始時間(startTime),
             * 如差值大于預定時間則返回空值,否則再次調用getConnection()。
             */
            while ( (con = getConnection()) == null) {
                try {
                    wait(timeout);
                }
                catch (InterruptedException e) {

                }
                if ( (new java.util.Date().getTime() - startTime) >= timeout) { //wait()返回的原因是超時
                    return null; //連接超時,釋放掉連接
                }
            }
            return con; //返回連接
        }

        private void log(String msg) {
            log.println(new java.util.Date() + ": " + msg);
        }

        /**
         * 將文本信息與異常寫入日志文件
         */
        private void log(Throwable e, String msg) {
            log.println(new java.util.Date() + ": " + msg);
            e.printStackTrace(log);
        }

        /**
         * 創建新連接由newConnection()方法實現。
         * 創建過程與是否已經指定數據庫帳號、密碼有關。
         * JDBC的DriverManager類提供多個getConnection()方法,這些方法要用到JDBC URL與其它一些參數,如用戶帳號和密碼等。
         * DriverManager將使用指定的JDBC URL確定適合于目標數據庫的驅動程序及建立連接。
         */
        private Connection newConnection() {
            Connection con = null;
            try {
                if (user == null) {
                    con = DriverManager.getConnection(URL); //保持數據庫連接加載數據庫驅動程序
                }
                else {
                    con = DriverManager.getConnection(URL, user, password);
                }
                Debug.writeLog("連接池" + name + "創建一個新的連接"); //21、如果有用戶連接就寫入日志說明有用戶創建了連接
            }
            catch (SQLException e) {
                Debug.writeLog("無法創建下列URL的連接: " + URL);
                e.printStackTrace(System.out);
                return null;
            }
            if (con == null) {
                Debug.writeLog(
                    "DBConnectionPool newConnection(), The Returned Con is null");
            }
            return con;
        }

        /**
         * 實現的release()方法供DBConnectionManager調用。
         * 該方法遍歷freeConnections向量并關閉所有連接,然后從向量中刪除這些連接。

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一区在线| 久久99精品久久久久久动态图| 国产麻豆精品在线观看| 91精品国产全国免费观看| 亚洲国产va精品久久久不卡综合| 成人99免费视频| 成人免费在线观看入口| www.色精品| 日韩久久一区二区| av影院午夜一区| 中文字幕佐山爱一区二区免费| 成人av资源网站| 亚洲三级电影网站| 成人av免费在线观看| 精品久久久久久久久久久久包黑料 | 精品少妇一区二区三区视频免付费| 亚洲成a人v欧美综合天堂| 欧美日韩国产另类不卡| 强制捆绑调教一区二区| 337p粉嫩大胆噜噜噜噜噜91av| 黄色日韩三级电影| 国产日韩精品一区二区三区| 97久久人人超碰| 一区二区高清在线| 欧美日韩黄视频| 蜜臀久久99精品久久久久宅男| 日韩视频一区二区三区| 国产精品中文字幕日韩精品| 中文字幕巨乱亚洲| 欧美亚洲国产bt| 免费在线观看成人| 久久精品夜色噜噜亚洲a∨| www.欧美.com| 五月综合激情网| 久久伊人蜜桃av一区二区| 91在线免费看| 日韩国产欧美在线观看| 久久精品一区二区三区不卡牛牛| 不卡一区在线观看| 亚洲成人手机在线| 国产精品青草综合久久久久99| 一区二区三区四区不卡在线| 美女视频网站黄色亚洲| 黄一区二区三区| 国产精品乱人伦中文| 欧美在线观看视频在线| 精品写真视频在线观看| 亚洲欧洲日韩av| 8v天堂国产在线一区二区| 国产黄色精品网站| 午夜精品久久久久久久久久久 | 成人免费看片app下载| 一区二区三区日韩精品| 久久精品一区二区三区不卡| 欧美视频一区二区三区四区| 激情图片小说一区| 午夜精品久久久久久久蜜桃app | 国产午夜精品理论片a级大结局| 日本高清不卡视频| 国产麻豆视频精品| 日韩国产成人精品| 国产精品超碰97尤物18| 精品国产91洋老外米糕| 欧美日韩五月天| k8久久久一区二区三区| 美女高潮久久久| 午夜视频一区在线观看| 亚洲男人的天堂一区二区| 久久一区二区视频| 欧美一区二区三区色| 日本道精品一区二区三区| 国产成人午夜视频| 另类人妖一区二区av| 婷婷丁香激情综合| 亚洲午夜在线视频| 亚洲天堂av一区| 国产精品日韩成人| 欧美国产综合一区二区| 精品国产乱码久久久久久闺蜜 | 国产精品99久久久久久久女警 | 欧美日韩成人激情| 91社区在线播放| 国产精品 日产精品 欧美精品| 日本亚洲最大的色成网站www| 亚洲精选在线视频| 亚洲同性gay激情无套| 国产精品国产三级国产有无不卡 | 中文字幕精品综合| 国产天堂亚洲国产碰碰| 国产三区在线成人av| 久久精品综合网| 国产日韩精品一区二区三区| 欧美国产精品v| 亚洲国产精品99久久久久久久久| 精品久久免费看| 久久久99精品免费观看| 国产片一区二区| 国产精品萝li| 亚洲免费观看高清完整版在线| 亚洲人成网站色在线观看| 亚洲美女偷拍久久| 亚洲自拍欧美精品| 视频一区二区国产| 久久99热这里只有精品| 国产精品影音先锋| 91亚洲精品久久久蜜桃网站| 国产高清一区日本| 不卡的看片网站| 久久精品国产免费| 韩国精品在线观看| 国产成人精品免费网站| 精品国产乱子伦一区| 日韩三级高清在线| 久久奇米777| 亚洲小说欧美激情另类| 免费看日韩精品| 免费成人在线观看| 99久久综合狠狠综合久久| 在线精品视频免费观看| 久久综合色综合88| 一区二区三区四区亚洲| 久久国产夜色精品鲁鲁99| voyeur盗摄精品| 69久久夜色精品国产69蝌蚪网| 国产清纯白嫩初高生在线观看91| 亚洲男人都懂的| 国产精品一区二区视频| 一本一本大道香蕉久在线精品| 日韩欧美成人一区二区| 中文字幕一区二区三区在线观看| 亚洲在线观看免费| 韩国欧美一区二区| 欧美在线啊v一区| 久久奇米777| 婷婷久久综合九色综合伊人色| 国产毛片精品国产一区二区三区| 91国偷自产一区二区使用方法| 欧美精品丝袜中出| 中文字幕在线观看不卡视频| 午夜电影网一区| 国产精品亚洲人在线观看| 91久久精品一区二区| 日韩一区二区麻豆国产| 亚洲欧美视频在线观看| 国产专区综合网| 欧美日韩精品欧美日韩精品一| 国产午夜亚洲精品羞羞网站| 日韩在线一区二区| 色综合天天综合网天天狠天天| 精品捆绑美女sm三区| 亚洲成人资源网| 一本色道**综合亚洲精品蜜桃冫 | 国产婷婷色一区二区三区在线| 亚洲国产成人av网| 91在线精品一区二区| 精品理论电影在线| 婷婷丁香激情综合| 91老司机福利 在线| 久久精品网站免费观看| 日本欧美一区二区三区| 色婷婷av一区二区三区软件 | 韩国三级电影一区二区| 欧美日韩在线不卡| 综合欧美亚洲日本| 国产成人午夜精品5599| 欧美精品一区二区三区一线天视频| 亚洲成人av资源| 色综合激情久久| 国产精品久久久久久妇女6080 | 北岛玲一区二区三区四区| 久久综合九色欧美综合狠狠| 日韩av电影天堂| 欧美日韩国产不卡| 亚洲一区免费视频| 色综合亚洲欧洲| 亚洲精品日韩专区silk| 99精品视频在线播放观看| 中文字幕一区日韩精品欧美| 成人精品在线视频观看| 中文字幕第一区综合| 国产xxx精品视频大全| 久久久久久久久久久久久久久99| 蜜臀av性久久久久av蜜臀妖精 | 亚洲伊人色欲综合网| 91国偷自产一区二区三区成为亚洲经典 | 中文一区二区完整视频在线观看| 国产成人av福利| 日韩一区在线看| 在线中文字幕一区二区| 青娱乐精品视频| 久久精品视频一区二区| www.亚洲在线| 五月天久久比比资源色| 久久夜色精品一区| 91美女片黄在线| 日本美女一区二区三区| 国产日韩成人精品| 欧美专区日韩专区| 黑人巨大精品欧美一区| 亚洲三级在线免费观看|