青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Khan's Notebook GCC/GNU/Linux Delphi/Window Java/Anywhere

路漫漫,長修遠,我們不能沒有錢
隨筆 - 173, 文章 - 0, 評論 - 257, 引用 - 0
數據加載中……

Java 的簡單數據庫連接池實現

一個連接容器,記錄連接和連接使用狀況
package db.khan;

import java.sql.*;

/*數據庫連接容器
 * 
*/

public class DBPoolCon {
  
/*容器中的連接*/
  
public Connection con = null;

  
public int nUsedTimes = 0;

  DBPoolCon() 
{
  }


  
public Connection get() {
    
return con;
  }

}


一個操作和管理連接容器的連接池
package db.khan;

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

/**連接池類
 * 
*/

public class DBConPool {
  
protected LinkedList listCon = new LinkedList();// 一個存放鏈接池的鏈表
  protected String DBUrl = null;
  
protected String DBUser = null;
  
protected String DBPasswd = null;
  
  
/**最大連接數*/
  
protected int nMaxCon = 0;
  
  
/**連接最大使用時間*/
  
protected int nMaxUsedTime = 0;
  
  
/**當前已用連接數*/
  
protected int nConNum = 0;

  
/**構造器
   * 
@param String DBUrl
   * 
@param String DBUser
   * 
@param String DBPasswd
   * 
@param int nMaxCon
   * 
@param int nMaxUsedTime*/

  DBConPool(String DBUrl, String DBUser, String DBPasswd, 
int nMaxCon, int nMaxUsedTime) {
    
this.DBUrl = DBUrl;
    
this.DBUser = DBUser;
    
this.DBPasswd = DBPasswd;

    
this.nMaxCon = nMaxCon;
    
this.nMaxUsedTime = nMaxUsedTime;
  }


  
/**從連接池中取得連接(線程安全函數)
   * 
@return DBPoolCon 返回的數據庫連接容器
   * 
*/

  
synchronized public DBPoolCon get() {
    
if (listCon.size() > 0{//有連接時,直接取得連接
      return (DBPoolCon) listCon.removeFirst();
    }

    
if (nConNum < nMaxCon) {//如果沒有多余連接,但連接池未滿,新建一個連接
      return createCon();
    }

    
    System.out.println(
"Fail to get DB con, too many con: " + nConNum + " max:" + nMaxCon);
    
return null;
  }


  
/**銷毀連接
   * 
@param  DBPoolCon pCon*/

  
synchronized public void release(DBPoolCon pCon) {
    pCon.nUsedTimes
++;
    
if (pCon.nUsedTimes > nMaxUsedTime) {//如果使用時間大于最大使用時間,則該連接被回收
      try {
        nConNum
--;
        pCon.con.close();
        System.out.println(
"DB Con closed for used out");
      }
 catch (Exception e) {
        System.err.println(
"Fail to close DB Con");
      }

    }
 else {  //否則,該連接被重新分配
      listCon.add(pCon);
    }

  }


  
/**建立連接容器
   * 
@return DBPoolCon 返回一個連接容器*/

  
protected DBPoolCon createCon() {
    DBPoolCon pCon 
= new DBPoolCon();
    
try {
      pCon.con 
= DriverManager.getConnection(DBUrl, DBUser, DBPasswd);
      pCon.con.setAutoCommit(
true);
      nConNum
++;
      System.out.println(
"DB Con created, con num:" + nConNum + " max:" + nMaxCon);
    }
 catch (Exception e) {
      System.err.println(
"Fail to create DB Con");
    }

    
return pCon;
  }


  
/**回收器
   * 將連接池中的所有連接關閉
*/

  
protected void finalize() {
    
try {
      
while (listCon.size() > 0{
        DBPoolCon pCon 
= (DBPoolCon) listCon.removeFirst();
        pCon.con.close();
      }

    }
 catch (Exception e) {
      System.err.println(
"Fail to close DB Con");
    }

  }

}

posted on 2006-03-05 17:36 Khan 閱讀(1760) 評論(0)  編輯 收藏 引用 所屬分類: 跨平臺開發Java

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩视频不卡| 欧美在线视频一区二区三区| 欧美a级片一区| 久久成人人人人精品欧| 欧美一区1区三区3区公司| 亚洲欧美日韩国产成人| 一区二区欧美精品| 亚洲视频免费观看| 午夜久久久久久| 欧美伊人影院| 另类av一区二区| 欧美精品一区在线播放| 欧美色图五月天| 国产精品v欧美精品v日韩| 国产精品久久久久高潮| 国产精品日本精品| 国产一区二区三区久久久久久久久| 国产揄拍国内精品对白| 在线观看91精品国产入口| 最新日韩在线视频| 亚洲午夜在线观看视频在线| 欧美一区二区在线| 欧美成人精品影院| 一本一本久久a久久精品综合麻豆| 亚洲图片你懂的| 久久久av网站| 欧美视频中文字幕在线| 国内精品久久久久久影视8| 亚洲精品视频在线播放| 午夜精品一区二区三区四区| 美腿丝袜亚洲色图| 一区二区三区国产盗摄| 久久大香伊蕉在人线观看热2| 欧美大尺度在线观看| 国产精品福利片| 国产日韩欧美一区| 亚洲精品免费在线播放| 久久er99精品| 夜夜狂射影院欧美极品| 裸体一区二区| 国产欧美在线播放| 一本色道88久久加勒比精品| 久久人人97超碰国产公开结果 | 亚洲一区二区三区激情| 久久最新视频| 国产字幕视频一区二区| 亚洲在线电影| 亚洲人成啪啪网站| 亚洲永久字幕| 欧美日韩国产影片| 亚洲高清不卡在线| 欧美综合77777色婷婷| 亚洲天堂av综合网| 欧美一区二区三区在| 欧美日韩免费视频| 最新亚洲一区| 欧美国产精品va在线观看| 午夜欧美视频| 国产视频久久久久久久| 亚洲欧美日本精品| 艳妇臀荡乳欲伦亚洲一区| 欧美激情网友自拍| 亚洲国产欧美日韩精品| 免费视频一区| 久久久久se| 午夜久久久久| 国产精品一区二区久久久久| 亚洲在线播放| 亚洲男人第一av网站| 国产精品福利网站| 午夜精品美女自拍福到在线| 宅男噜噜噜66一区二区66| 欧美日韩大片| 亚洲一区在线播放| 亚洲午夜性刺激影院| 欧美日在线观看| 亚洲精品久久| 亚洲精品久久视频| 欧美午夜精品久久久久久人妖 | 亚洲制服丝袜在线| 国产精品久久久久久一区二区三区| 一区二区三区视频在线看| 亚洲精品一区二区三区四区高清| 欧美激情91| 亚洲午夜久久久久久久久电影院| 中文在线资源观看网站视频免费不卡| 国产精品成人一区二区三区夜夜夜 | 欧美一级久久久| 午夜激情一区| 在线观看亚洲精品视频| 亚洲国产欧美一区| 国产精品va在线播放我和闺蜜| 久久精品日韩欧美| 美腿丝袜亚洲色图| 亚洲一区三区视频在线观看| 欧美怡红院视频一区二区三区| 亚洲第一级黄色片| av成人手机在线| 激情视频亚洲| 99精品久久久| 精品999久久久| 99re视频这里只有精品| 国产资源精品在线观看| 亚洲国产欧美不卡在线观看| 国产精品久久久久久久久婷婷| 麻豆精品传媒视频| 欧美日韩国产综合视频在线观看中文 | 亚洲欧美不卡| 久久精品国产999大香线蕉| 91久久精品日日躁夜夜躁国产| 欧美激情麻豆| 玖玖综合伊人| 欧美一区二区三区免费视| 六月丁香综合| 久久久久久综合| 国产精品国内视频| 亚洲人成在线观看| 亚洲电影在线播放| 亚洲香蕉成视频在线观看| 亚洲国产成人av| 欧美一区久久| 欧美影院视频| 欧美午夜无遮挡| 亚洲黄色在线看| 亚洲丰满在线| 久久久精品2019中文字幕神马| 久久不见久久见免费视频1| 国产精品啊v在线| 日韩视频一区二区三区在线播放| 亚洲娇小video精品| 久久综合给合久久狠狠色 | 亚洲男女毛片无遮挡| 亚洲午夜av| 欧美日韩伊人| 亚洲美女一区| 99精品国产一区二区青青牛奶 | 国产综合色精品一区二区三区 | 狠狠色狠狠色综合日日91app| 亚洲美女精品久久| 国产麻豆精品视频| 亚洲欧洲在线一区| 国内久久精品视频| 宅男66日本亚洲欧美视频| 亚洲韩日在线| 久久黄色小说| 亚洲人成在线观看| 欧美激情免费在线| 欧美高清视频www夜色资源网| 国产一区二区三区免费不卡 | 亚洲欧美日本国产专区一区| 欧美国产乱视频| 免费不卡在线视频| 欧美aⅴ99久久黑人专区| 最新国产精品拍自在线播放| 亚洲大片免费看| 久久久久久久久蜜桃| 久久久久久网| 久久亚洲综合色一区二区三区| 欧美一区二区三区四区夜夜大片| 香蕉久久一区二区不卡无毒影院| 999亚洲国产精| 久久久免费精品视频| 久久精品国内一区二区三区| 欧美日韩高清在线播放| 亚洲国产日韩综合一区| 亚洲日本免费| 欧美国产欧美综合| 亚洲毛片一区| 久久嫩草精品久久久精品| 在线国产欧美| 欧美成人情趣视频| 欧美国产第一页| 亚洲国产精品v| 蜜桃av一区| 亚洲欧洲日夜超级视频| 99热在这里有精品免费| 欧美另类视频在线| 欧美中文字幕视频在线观看| 久久综合电影一区| 亚洲国产小视频| 欧美三区在线视频| 久久久久久久波多野高潮日日| 老司机免费视频久久| 亚洲精品国产精品国自产观看 | 久久一区欧美| 一区二区三区高清| 国产精品―色哟哟| 久久久久久久久岛国免费| 欧美顶级大胆免费视频| 国产一级一区二区| 欧美日韩综合在线| 亚洲欧美综合一区| 久久蜜桃精品| 夜夜夜久久久| 亚洲激情成人网| 国产精品v日韩精品| 久久久无码精品亚洲日韩按摩| 最新成人在线| 亚洲欧美国产精品桃花| 在线免费精品视频|