jakarta commons-dbcp
1.DBCP简介
网络程序的设计,很多都涉及到和关系型数据库的交互操作,一般的操作方式都是使用的时候创建到数据库的连
接,然后进行各种操作,这种简单的操作方式带来的问题便是数据库的频繁的打开和关闭,以及Transtion的执
行,这是一种很耗费时间和资源的操作。于是数据库缓冲池DBCP就出现了,这个包是从pool包发展出来的。
2.DBCP实现的基本流程
1.创建enericobjectPool实例
GenericObjectPool pool = new GenericObjectPool(null);
2.创建PoolableConnectionFactory
driverManagerConnectionFactory cf =
new DriverManagerConnectionFactory(
"JDBC:mysql://host/db", "username", "password");
PoolableConnectionFactory pcf =
new PoolableConnectionFactory(
CF, pool, null, "select * FROM MYSQL.db", false, true);
3.创建和注册PoolingDriver
new PoolingDriver().registerPool("myPool", pool);
到此为止,数据库缓冲池就创建完毕了.
3.Datasource的实现过程
DataSource在众多的JSP容器和应用程序中都已经实现,在容器或者应用服务器启动的时候,他会读取相关的
配置文件,自动完成DataSource的创建工作,我们一般只需要在服务器的配置文件中指定就可以了,这里贴出
实现的过程,便于大家理解它内部的实现机制,便于编程参考。
import Javax.sql.DataSource;
import java.sql.Connection;
import java.sql.Statement;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.apache.commons.dbcp.BasicDataSource;
public class BasicDataSourceExample {
public static void main(String[] args) {
// 创建BasicDataSource
System.out.println("Setting up data source.");
DataSource dataSource = setupDataSource(args[0]);
System.out.println("Done.");
//创建JDBC数据源
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.");
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10794571/viewspace-974825/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/10794571/viewspace-974825/