需要的jar包:1.commons-dbcp.jar
2.commons-collections.jar
3.commons-pool.jar
import java.io.FileInputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
import javax.sql.DataSource;
import org.apache.commons.dbcp.BasicDataSource;
public class DbcpConnection {
private static DataSource dataSource;
private static Connection con;
public DbcpConnection(){
}
public static Connection getConnection() {
if (dataSource == null) {
initDataSource();
}
try {
con = dataSource.getConnection();
print();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return con;
}
@SuppressWarnings("deprecation")
public static void initDataSource() {
FileInputStream is=null;
Properties p = new Properties();
String driverClassName=null;
String url=null;
String username=null;
String password=null;
int initialSize=0;
int minIdle=0;
int maxIdle=0;
int maxWait=0;
int maxActive=0;
try {
is= new FileInputStream("dbcp.properties");
p.load(is);
driverClassName = p.getProperty("dbcp.driverClassName");
url = p.getProperty("dbcp.url");
username = p.getProperty("dbcp.username");
password = p.getProperty("dbcp.password");
initialSize = Integer.parseInt(p.getProperty("dbcp.initialSize"));
minIdle = Integer.parseInt(p.getProperty("dbcp.minIdle"));
maxIdle = Integer.parseInt(p.getProperty("dbcp.maxIdle"));
maxWait = Integer.parseInt(p.getProperty("dbcp.maxWait"));
maxActive = Integer.parseInt(p.getProperty("dbcp.maxActive"));
} catch (NumberFormatException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
is.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
BasicDataSource ds = new BasicDataSource();
ds.setUrl(url);
ds.setDriverClassName(driverClassName);
ds.setUsername(username);
ds.setPassword(password);
ds.setInitialSize(initialSize); // 初始的连接数;
ds.setMaxActive(maxActive);
ds.setMinIdle(minIdle);
ds.setMaxIdle(maxIdle);
ds.setMaxWait(maxWait);
//ds.setRemoveAbandoned(true);
//ds.setRemoveAbandonedTimeout(2000);
dataSource = ds;
}
/* 用于测试连接状态的方法*/
public static void print(){
BasicDataSource ds=(BasicDataSource)dataSource;
System.out.println(ds.getInitialSize());
System.out.println(ds.getNumActive());
System.out.println(ds.getNumIdle());
System.out.println(ds.getDefaultAutoCommit());
}
}
2.数据库的连接属性的配置文件:dbcp.properties
dbcp.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
dbcp.url=jdbc:sqlserver://localhost:1433;DatabaseName=Library;userName=sa;password=123456
dbcp.username=sa
dbcp.password=123456
dbcp.initialSize=10
dbcp.minIdle=5
dbcp.maxIdle=15
dbcp.maxWait=3000
dbcp.maxActive=20
分享到:
相关推荐
在Java开发中,数据库连接管理是一项关键任务,而Apache的DBCP(Database Connection Pool)库则为开发者提供了一个高效、可配置的数据库连接池解决方案。DBCP是基于Jakarta Commons项目下的两个组件——Commons ...
DBCP(Database Connection Pool)是Apache组织提供的一个开源数据库连接池组件,全称为"Commons DBCP"。它在Java应用中起到了管理和复用数据库连接的作用,从而提高应用程序的性能,减少数据库资源的消耗。在Java ...
DBCP通过维护一个数据库连接的池,当应用程序需要连接时,可以从池中获取一个已建立的连接,使用完毕后归还回池而不是关闭连接。这样可以避免频繁地打开和关闭连接,降低系统开销,并且能更好地支持多线程环境。 ...
DBCP就是这样的一个连接池实现,它允许开发者预先配置一定数量的数据库连接,当应用需要时,可以从连接池中获取一个已存在的连接,使用完毕后再归还给连接池,而不是直接关闭。 DBCP主要包括两个主要的组件:...
DBCP(Database Connection Pool)是Apache的一个开源项目Commons DBCP,它是Java数据库连接池的一种实现。在Java应用中,DBCP被广泛用于管理数据库连接,以提高应用程序的性能和资源利用率。数据库连接池的基本原理...
JavaEE DBCP简单案例
3. 初始化连接池:在代码中,使用`BasicDataSource`类来实例化一个数据源,加载配置文件,并设置其他必要的属性。 4. 获取和释放连接:通过数据源的`getConnection()`方法获取数据库连接,使用完毕后,通过`close()`...
DBCP(Database Connection Pool)是Apache Commons项目中的一个数据库连接池组件,全称为"Commons DBCP"。它提供了一种有效管理数据库连接的方法,避免了频繁创建和关闭数据库连接导致的性能损耗。在Java应用程序中...
DBCP(Database Connection Pool)是Apache软件基金会的一个开源项目,全称为Apache Commons DBCP,它提供了一个数据库连接池服务。在Java应用中,DBCP常用于管理数据库连接,提高应用性能,通过复用已存在的数据库...
然后通过JDBC的DriverManagerDataSource或者BasicDataSource类来实例化一个数据源,应用程序就可以通过这个数据源来获取数据库连接。 总的来说,Apache DBCP是Java应用程序中实现数据库连接池的一个经典选择,它与...
数据库连接池是在应用服务器启动时预创建一定数量的数据库连接,并将这些连接保存在一个池中。当应用程序需要访问数据库时,不是直接创建新的连接,而是从池中获取一个已存在的连接;使用完毕后,连接会被归还到池中...
DBCP(Jakarta Commons DBCP)数据源是Apache软件基金会的一个开源项目,它提供了一个数据库连接池服务。在Java应用程序中,特别是那些基于Servlet容器(如Tomcat)的应用,DBCP是一个常用的数据库连接管理工具。它...
DBCP(Database Connection Pool)是Apache组织提供的一个开源数据库连接池组件,主要包含在Apache Commons DBCP项目中。这个库允许开发者管理数据库连接,通过池化的方式提高应用程序的性能和效率。DBCP是一个基于...
DBCP(Database Connection Pool)是Apache的一个开源项目,全称为Apache Commons DBCP,它提供了一个数据库连接池组件。在Java应用中,特别是在服务器端,为了提高数据库操作的性能和效率,通常会使用数据库连接池...
DBCP(Database Connection Pool)是Apache Commons项目中的一个数据库连接池组件,全称为"Commons DBCP"。它提供了一种在Java应用程序中管理数据库连接的方法,通过池化技术来提高性能和效率。数据库连接池是应用...
以下是一个简单的使用DBCP连接池的Java代码示例: ```java import org.apache.commons.dbcp2.BasicDataSource; public class JdbcDbcpExample { public static void main(String[] args) { // 初始化连接池 ...
DBCP(Database Connection Pool)是Apache Commons项目中的一个数据库连接池组件,它的全称是Apache Commons DBCP。DBCP的主要功能是管理数据库连接,通过池化技术提高数据库操作的性能,减少创建和释放数据库连接...
DBCP数据库连接池的引入,使得应用程序可以预先创建并维护一定数量的数据库连接,当需要与数据库通信时,从连接池中获取一个已存在的连接,用完后不是立即关闭,而是将其归还回连接池,供后续使用。这样减少了频繁的...
Apache Commons DBCP 1.2.2 是一个在Java应用程序中管理数据库连接池的开源库。这个版本的DBCP是Apache Commons项目的一部分,旨在提供一个健壮、高性能的数据库连接池实现,以提高Java应用的数据库访问效率。在本篇...
Apache Commons DBCP(Database Connection Pool)是Apache软件基金会开发的一个开源项目,它提供了一个数据库连接池组件。数据库连接池在处理多用户并发访问时,能够有效地管理数据库连接,提高系统的性能和效率。...