[转]DBCP连接池的最简单应用(用于ORACLE数据库)
http://blog.csdn.net/iihero/article/details/8254107
http://www.programgo.com/article/81693457907/
鉴于有人问起DBCP直接用于JDBC连接的问题,我做了一个最简单的示例。所有资源来源于网上。它不需要什么Web容器,就是一简单的控制台应用。
资源:
http://apache.etoak.com//commons/pool/binaries/commons-pool-1.5.6-bin.zip
http://labs.renren.com/apache-mirror//commons/dbcp/binaries/commons-dbcp-1.4-bin.zip
http://download.java.net/maven/1/javaee/jars/javaee-api-5.jar
当然,还有oracle jdbc要用的ojdbc14.jar (适用于oracle9i及以上版本)
工程文件:放到这里了。http://dl.iteye.com/topics/download/210279f0-f752-37a6-969f-d58ba13cc394
数据库连接信息:
jdbc:oracle:thin:scott/tiger@sean-m700:1521:ora92
sean-m700是主机名,ora92是oracle数据库的instance ID. 我手头的机器上没有安装oracle数据库,用的是很早以前的一个oracle9.2的拷贝,重新安装实例和相应服务得来的。
源码如下:借化献佛,源码也是从网上得来的。(http://svn.apache.org/viewvc/commons/proper/dbcp/trunk/doc/BasicDataSourceExample.Java?revision=1100136&view=markup)
- /*
- //
- 33 // Here's a simple example of how to use the BasicDataSource.
- 34 //
- 35
- 36 //
- 37 // Note that this example is very similiar to the PoolingDriver
- 38 // example.
- 39
- 40 //
- 41 // To compile this example, you'll want:
- 42 // * commons-pool-1.5.6.jar
- 43 // * commons-dbcp-1.3.jar (JDK 1.4-1.5) or commons-dbcp-1.4 (JDK 1.6+)
- 44 // * j2ee.jar (for the javax.sql classes)
- 45 // in your classpath.
- 46 //
- 47 // To run this example, you'll want:
- 48 // * commons-pool-1.5.6.jar
- 49 // * commons-dbcp-1.3.jar (JDK 1.4-1.5) or commons-dbcp-1.4 (JDK 1.6+)
- 50 // * j2ee.jar (for the javax.sql classes)
- 51 // * the classes for your (underlying) JDBC driver
- 52 // in your classpath.
- 53 //
- 54 // Invoke the class using two arguments:
- 55 // * the connect string for your underlying JDBC driver
- 56 // * the query you'd like to execute
- 57 // You'll also want to ensure your underlying JDBC driver
- 58 // is registered. You can use the "jdbc.drivers"
- 59 // property to do this.
- 60 //
- 61 // For example:
- 62 // java -Djdbc.drivers=oracle.jdbc.driver.OracleDriver \
- 63 // -classpath commons-pool-1.5.6.jar:commons-dbcp-1.4.jar:j2ee.jar:oracle-jdbc.jar:. \
- 64 // PoolingDataSourceExample
- 65 // "jdbc:oracle:thin:scott/tiger@myhost:1521:mysid"
- 66 // "SELECT * FROM DUAL"
- */
- /*
- The Oracle connection URL for the thin client-side driver ojdbc14.jar has the following format:
- jdbc:oracle:thin:[user/password]@[host][:port]:SID
- jdbc:oracle:thin:[user/password]@//[host][:port]/SID
- user - The login user name defined in the Oracle server.
- password - The password for the login user.
- host - The host name where Oracle server is running.
- Default is 127.0.0.1 - the IP address of localhost.
- port - The port number where Oracle is listening for connection.
- Default is 1521.
- SID - System ID of the Oracle server database instance.
- SID is a required value. By default, Oracle Database 10g Express
- Edition creates one database instance called XE.
- */
- import org.apache.commons.dbcp.BasicDataSource;
- import javax.sql.*;
- import java.sql.*;
- public class TestDataSource
- {
- /**
- * @param args
- */
- public static void main(String[] args)
- {
- System.out.println("Setting up data source.");
- String url = "jdbc:oracle:thin:scott/tiger@sean-m700:1521:ora92";
- DataSource dataSource = setupDataSource(url);
- System.out.println("Done...");
- // Now, we can use JDBC DataSource as we normally would.
- //
- Connection conn = null;
- Statement stmt = null;
- ResultSet rset = null;
- try {
- System.out.println("Creating connection.");
- conn = dataSource.getConnection();
- System.out.println("Creating statement.");
- stmt = conn.createStatement();
- System.out.println("Executing statement.");
- rset = stmt.executeQuery("select 1 from DUAL");
- System.out.println("Results:");
- int numcols = rset.getMetaData().getColumnCount();
- while(rset.next()) {
- for(int i=1;i<=numcols;i++) {
- System.out.print("\t" + rset.getString(i));
- }
- System.out.println("");
- }
- } catch(SQLException e) {
- e.printStackTrace();
- } finally {
- try { if (rset != null) rset.close(); } catch(Exception e) { }
- try { if (stmt != null) stmt.close(); } catch(Exception e) { }
- try { if (conn != null) conn.close(); } catch(Exception e) { }
- }
- }
- public static DataSource setupDataSource(String connectURI) {
- BasicDataSource ds = new BasicDataSource();
- ds.setDriverClassName("oracle.jdbc.driver.OracleDriver");
- ds.setUsername("scott");
- ds.setPassword("tiger");
- ds.setUrl(connectURI);
- return ds;
- }
- public static void printDataSourceStats(DataSource ds) {
- BasicDataSource bds = (BasicDataSource) ds;
- System.out.println("NumActive: " + bds.getNumActive());
- System.out.println("NumIdle: " + bds.getNumIdle());
- }
- public static void shutdownDataSource(DataSource ds) throws SQLException {
- BasicDataSource bds = (BasicDataSource) ds;
- bds.close();
- }
- }
不过,需要说明的是,DBCP连接池是几个开源连接池里最不适合用于生产环境的,经常会出现死连接现象。 而cp30和proxool都是不错的选择。DBCP用于测评开发环境,还是比较便利的。
[转]DBCP连接池的最简单应用(用于ORACLE数据库)的更多相关文章
- DBCP连接池简介
DBCP连接池简介 1.数据库连接基础 数据库连接池基础主要包括以下三个方面的内容:数据库连接池的基本概念.数据库连接池的工作原理.Java开源的连接池.下面将从这三个方面一一介绍: (1)数据库连接 ...
- JNDI和在tomcat中配置DBCP连接池 元数据的使用 DBUtils框架的使用 多表操作
1 JNDI和在tomcat中配置DBCP连接池 JNDI(Java Naming and Directory Interface),Java命名和目录接口,它对应于J2SE中的javax.namin ...
- 使用c3p0与DBCP连接池,造成的MySql 8小时问题解决方案
转自:http://blog.csdn.net/wangfayinn/article/details/24623575 c3p0数据库连接池mysql8小时 目录(?)[-] 基本问题解决 项目环境 ...
- 关于 Mybatis的原生连接池 和 DBCP 连接池
一 遇到的问题: 项目用的play框架,数据库DB2, 持久化框架是Mybatis, 连接池用的是Mybatis原生的,遇到的问题是:有时候抛出如下异常: play.api.UnexpectedEx ...
- DBUtils工具类和DBCP连接池
今日内容介绍 1.DBUtils2.处理结果集的八种方式3.连接池4.连接池的用法1 PrepareStatement接口预编译SQL语句 1.1 预处理对象 * 使用PreparedStatemen ...
- tomcat7使用dbcp连接池遇到的坑
项目部署在tomcat后每隔一段时间便会报错 Cause: java.sql.SQLException: Could not retrieve transation read-only status ...
- 采用DBCP连接池技术管理连接
DBCP的使用步骤步骤一:导包,使用第三方的道具,必须导入相应的jar包. 一般需要导入两个jar包: -commons-dbcp-1.x.jar包 -commons-pool-1.x.x.jar包 ...
- DBCP连接池使用问题
问题现象: 启动应用,访问无压力,一切正常,一段时间过后,应用访问异常. 问题分析: 1.web容器线程爆满,拒绝服务.由于应用并发量大,线程响应时间长增加,线程池连接数逐步递增直到爆满,导致应用拒绝 ...
- DBCP连接池介绍
DBCP连接池介绍 ----------------------------- 目前 DBCP 有两个版本分别是 1.3 和 1.4. DBCP 1.3 版本需要运行于 JDK 1.4-1.5 ,支持 ...
随机推荐
- Flash硬件原理
1.2.1. 什么是Flash Flash全名叫做Flash Memory,从名字就能看出,是种数据存储设备,存储设备有很多类,Flash属于非易失性存储设备(Non-volatile Memory ...
- windows系统yolov3的安装教程(图文)
记于 2018-05-19 13:21:13 距离开始着手安装yolov3已经过去将近20个小时,当然我并没有装那么久啦,就是大概4,5个小时这么久,网络上教程很少,步骤也千奇百怪,这次成功装好后就想 ...
- T-SQL ORDER BY子句 排序方式
MS SQL Server ORDER BY子句用于根据一个或多个列以升序或降序对数据进行排序. 默认情况下,一些数据库排序查询结果按升序排列. 语法 以下是ORDER BY子句的基本语法. SELE ...
- mysql 定时备份bat脚本 ,方便小型服务简单快速备份mysql
mysql定时备份bat脚本 echo 数据库为用户名为root 密码为root 数据库名为kdykt echo mysqldump 命令如果没有配置环境变量要在bin目录下执行 set " ...
- 前端 ---JS中的面向对象
JS中的面向对象 创建对象的几种常用方式 1.使用Object或对象字面量创建对象 2.工厂模式创建对象 3.构造函数模式创建对象 4.原型模式创建对象 1.使用Object或对象字面量创建对象 ...
- nodejs process.memoryUsage() rss等参数啥含义
1 前言 使用process.memoryUsage() ,然后可以得到一个对象如下: { rss: 4935680, heapTotal: 1826816, heapUsed: 650472, ex ...
- django的内置信号
Model singnalspre_init 在model执行构造方法之前自动触发post_init django的model在执行构造方法之后,自动触发pre_save django的对象保存之前, ...
- liunx tomcat 运行模式apr
tomcat运行模式一共三种:bio.nio.apr 网上对这三种运行模式的解释外: bio运行模式:阻塞式I/O操作,表示Tomcat使用的是传统的Java I/O操作(即java.io包及其子包) ...
- Confluence 6 配置日志
我们推荐你根据你的需求来配置你自己的 Confluence 日志.你可以有下面 2 种方法来修改你的日志: 通过 Confluence 管理员控制台进行配置 – 你的修改仅在本次修改有效,下次重启后将 ...
- Confluence 6 重构查找索引
查找索引是自动维护的,但是你有时候可能会因为你在查找的时候或查看者邮件主题出现了异常,或者你的 Confluence 实例升级到了新的版本,你可能需要手动重构索引. 进行搜索索引重构: 在屏幕的右上角 ...