动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.移动未来之一:搭建 WAP 应用开发.
.ORACLE没有自动增长的数据类型.
.Linux着作权须知.
.stty使用方法.
.Oracle数据库管理脚本介绍.
.Oracle10gR2 新视图:V$SESSION变.
.制作自己的Floppy-Linux Step By.
.Oracle中的用户管理的不完全恢复.
.Oracle的客户端工具--sql*plus.
.Linux上备份Oracle数据库脚本(16.
.如何在postfix中使用procmail.
.Oracle数据库技术(16).
.Oracle的标准系统服务脚本-for .
.PL/SQL序列.
.详解oracle9i Statspack 的安装和.
.带你快速了解wait等待事件及其处.
.Oracle数据库中分区表的操作方法.
.Linux Shadow-Password-HOWTO.
.临时表更适合做插入和查询操作.
.什么是 Linux.

Oracle数据库 关于连接池一

发表日期:2008-2-9 |


  到目前为目,JDBC2的连结池只是一个接口,没有真正的实现,JDBC3正在开发中,据报已经支持连结池,但JDBC3用了JNDI技术,连结池的配置可以让一个高手都烦死.
  
  目前第三方已经实现的连结池当然是poolman,1.0版对一般用户来说已经足够用了.配置也简单,2.0版虽然增加了一些功能,但配置也是采用JNDI,对RMI和EJB不懂的朋友可能很烦.建议用1.0的了.
  
  假如有爱好,自己也可以实现连结池,最要害的技术也就是把连结作为参数传给一个BEAN,用完后返回这个参数连结而不是关闭.
  
  下面是一个简单的实现:
  
  DBConnectionManager.Java程序清单如下:
  
  001 import java.io.*;
  002 import java.sql.*;
  003 import java.util.*;
  004 import java.util.Date;
  005
  006 /**
  007 * 治理类DBConnectionManager支持对一个或多个由属性文件定义的数据库连接
  008 * 池的访问.客户程序可以调用getInstance()方法访问本类的唯一实例.
  009 */
  010 public class DBConnectionManager {
  011 static private DBConnectionManager instance; // 唯一实例
  012 static private int clients;
  013
  014 private Vector drivers = new Vector();
  015 private PrintWriter log;
  016 private Hashtable pools = new Hashtable();
  017
  018 /**
  019 * 返回唯一实例.假如是第一次调用此方法,则创建实例
  020 *
  021 * @return DBConnectionManager 唯一实例
  022 */
  023 static synchronized public DBConnectionManager getInstance() {
  024 if (instance == null) {
  025 instance = new DBConnectionManager();
  026 }
  027 clients++;
  028 return instance;
  029 }
  030
  031 /**
  032 * 建构函数私有以防止其它对象创建本类实例
  033 */
  034 private DBConnectionManager() {
  035 init();
  036 }
  037
  038 /**
  039 * 将连接对象返回给由名字指定的连接池
  040 *
  041 * @param name 在属性文件中定义的连接池名字
  042 * @param con 连接对象\\r
  
  043 */
  044 public void freeConnection(String name, Connection con) {
  045 DBConnectionPool pool = (DBConnectionPool) pools.get(name);
  046 if (pool != null) {
  047 pool.freeConnection(con);
  048 }
  049 }
  050
  051 /**
  052 * 获得一个可用的(空闲的)连接.假如没有可用连接,且已有连接数小于最大连接数
  053 * 限制,则创建并返回新连接
  054 *
  055 * @param name 在属性文件中定义的连接池名字
  056 * @return Connection 可用连接或null
  057 */
  058 public Connection getConnection(String name) {
  059 DBConnectionPool pool = (DBConnectionPool) pools.get(name);
  060 if (pool != null) {
  061 return pool.getConnection();
  062 }
  063 return null;
  064 }
  065
  066 /**
  067 * 获得一个可用连接.若没有可用连接,且已有连接数小于最大连接数限制,
  068 * 则创建并返回新连接.否则,在指定的时间内等待其它线程释放连接.
  069 *
  070 * @param name 连接池名字
  071 * @param time 以毫秒计的等待时间\\r
  
  072 * @return Connection 可用连接或null
  073 */
  074 public Connection getConnection(String name, long time) {
  075 DBConnectionPool pool = (DBConnectionPool) pools.get(name);
  076 if (pool != null) {
  077 return pool.getConnection(time);
  078 }
  079 return null;
  080 }
  081
  082 /**
  083 * 关闭所有连接,撤销驱动程序的注册\\r
  
  084 */
  085 public synchronized void release() {
  086 // 等待直到最后一个客户程序调用
  087 if (--clients !
= 0) {
  088 return;
  089 }
  090
  091 Enumeration allPools = pools.elements();
  092 while (allPools.hasMoreElements()) {
  093 DBConnectionPool pool = (DBConnectionPool) allPools.nextElement();
  094 pool.release();
  095 }
  096 Enumeration allDrivers = drivers.elements();
  097 while (allDrivers.hasMoreElements()) {
  098 Driver driver = (Driver) allDrivers.nextElement();
  099 try {
  100 DriverManager.deregisterDriver(driver);
  101 log("撤销JDBC驱动程序 " + driver.getClass().getName()+"的注册\\\");
  102 }
  103 catch (SQLException e) {
  104 log(e, "无法撤销下列JDBC驱动程序的注册: " + driver.getClass().getName());
  105 }
  106 }
  107 }
  108
  109 /**
  110 * 根据指定属性创建连接池实例.
  111 *
  112 * @param props 连接池属性
  113 */
  114 private void createPools(Properties props) {
  115 Enumeration propNames = props.propertyNames();
  116 while (propNames.hasMoreElements()) {
  117 String name = (String) propNames.nextElement();
  118 if (name.endsWith(".url")) {
  119 String poolName = name.substring(0, name.lastIndexOf("."));
  120 String url = props.getProperty(poolName + ".url");
  121 if (url == null) {
  122 log("没有为连接池" + poolName + "指定URL");
  123 continue;
  124 }
  125 String user = props.getProperty(poolName + ".user");
  126 String passWord = props.getProperty(poolName + ".password");
  127 String maxconn = props.getProperty(poolName + ".maxconn", "0");
  128 int max;
  129 try {
  130 max = Integer.valueOf(maxconn).intValue();
  131 }
  132 catch (NumberFormatException e) {
  133 log("错误的最大连接数限制: " + maxconn + " .连接池: " + poolName);
  134 max = 0;
  135 }
  136 DBConnectionPool pool =
  137 new DBConnectionPool(poolName, url, user, password, max);
  138 pools.put(poolName, pool);
  139 log("成功创建连接池" + poolName);
  140 }
  141 }
  142 }
  143
  144 /**
  145 * 读取属性完成初始化
  146 */
  147 private void init() {
  148 InputStream is = getClass().getResourceAsStream("/db.properties");
  149 Properties dbProps = new Properties();
  150 try {
  151 dbProps.load(is);
  152 }
  153 catch (Exception e) {
  154 System.err.println("不能读取属性文件. " +
  155 "请确保db.properties在CLASSPATH指定的路径中");
  156 return;
  157 }
  158 String logFile = dbProps.getProperty("logfile", "DBConnectionManager.log");
  159 try {
  160 log = new PrintWriter(new FileWriter(logFile, true), true);
  161 }
  162 catch (IOException e) {
  163 System.err.println("无法打开日志文件: " + logFile);
  164 log = new PrintWriter(System.err);
  165 }
  166 loadDrivers(dbProps);

  167 createPools(dbProps);
  168 }
  169
  170 /**
  171 * 装载和注册所有JDBC驱动程序\\r
  
  172 *
  173 * @param props 属性
  174 */
  175 private void loadDrivers(Properties props) {
  176 String driverClasses = props.getProperty("drivers");
  177 StringTokenizer st = new StringTokenizer(driverClasses);
  178 while (st.hasMoreElements()) {
  179 String driverClassName = st.nextToken().trim();
  180 try {
  181 Driver driver = (Driver)
  182 Class.forName(driverClassName).newInstance();
  183 DriverManager.registerDriver(driver);
  184 drivers.addElement(driver);
  185 log("成功注册JDBC驱动程序\\\" + driverClassName);
  186 }
  187 catch (Exception e) {
  188 log("无法注册JDBC驱动程序: " +
  189 driverClassName + ", 错误: " + e);
  190 }
  191 }
  192 }
  193
  194 /**
  195 * 将文本信息写入日志文件
  196 */
  197 private void log(String msg) {
  198 log.println(new Date() + ": " + msg);
  199 }
  200
  201 /**
  202 * 将文本信息与异常写入日志文件
  203 */
  204 private void log(Throwable e, String msg) {
  205 log.println(new Date() + ": " + msg);
  206 e.printStackTrace(log);
  207 }
  208
  209 /**
  210 * 此内部类定义了一个连接池.它能够根据要求创建新连接,直到预定的最\\r
上一篇:Oracle Portal网站开发 人气:565
下一篇:Oracle数据库 关于连接池二 人气:511
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-6 Movie34电影搜索引擎 v3.0
2008-9-6 wap2.0仿帝国建站喜用 v2.0
2008-9-6 免费人才招聘网 宽屏版 v3.01
2008-9-6 喜喔喔视频采集程序 v1.0 beta
2008-9-6 ASP客户管理系统
2008-9-6 主流驿站中秋祝福程序
2008-9-6 php实现msn协议的类
2008-9-5 Coppermine Photo Gallery v1.4.
2008-9-5 清松网络日记本 v2.4
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵