`
skewen
  • 浏览: 74857 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

使用DBCP的一个实例

阅读更多

需要的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

 

1
1
分享到:
评论

相关推荐

    使用dbcp需要用到的jar包

    在Java开发中,数据库连接管理是一项关键任务,而Apache的DBCP(Database Connection Pool)库则为开发者提供了一个高效、可配置的数据库连接池解决方案。DBCP是基于Jakarta Commons项目下的两个组件——Commons ...

    dbcp连接池小例子

    DBCP(Database Connection Pool)是Apache组织提供的一个开源数据库连接池组件,全称为"Commons DBCP"。它在Java应用中起到了管理和复用数据库连接的作用,从而提高应用程序的性能,减少数据库资源的消耗。在Java ...

    JavaEE 使用Tomcat的自带DBCP管理数据源案例

    DBCP通过维护一个数据库连接的池,当应用程序需要连接时,可以从池中获取一个已建立的连接,使用完毕后归还回池而不是关闭连接。这样可以避免频繁地打开和关闭连接,降低系统开销,并且能更好地支持多线程环境。 ...

    dbcp jar包 dbcp jar 包

    DBCP就是这样的一个连接池实现,它允许开发者预先配置一定数量的数据库连接,当应用需要时,可以从连接池中获取一个已存在的连接,使用完毕后再归还给连接池,而不是直接关闭。 DBCP主要包括两个主要的组件:...

    DBCP连接池和下载附件实例

    DBCP(Database Connection Pool)是Apache的一个开源项目Commons DBCP,它是Java数据库连接池的一种实现。在Java应用中,DBCP被广泛用于管理数据库连接,以提高应用程序的性能和资源利用率。数据库连接池的基本原理...

    JavaEE DBCP简单案例

    JavaEE DBCP简单案例

    dbcp连接池使用例子

    3. 初始化连接池:在代码中,使用`BasicDataSource`类来实例化一个数据源,加载配置文件,并设置其他必要的属性。 4. 获取和释放连接:通过数据源的`getConnection()`方法获取数据库连接,使用完毕后,通过`close()`...

    dbcp连接池所使用的jar和案例

    DBCP(Database Connection Pool)是Apache Commons项目中的一个数据库连接池组件,全称为"Commons DBCP"。它提供了一种有效管理数据库连接的方法,避免了频繁创建和关闭数据库连接导致的性能损耗。在Java应用程序中...

    DBCP需要的4个JAR包

    DBCP(Database Connection Pool)是Apache软件基金会的一个开源项目,全称为Apache Commons DBCP,它提供了一个数据库连接池服务。在Java应用中,DBCP常用于管理数据库连接,提高应用性能,通过复用已存在的数据库...

    dbcp相关jar包

    然后通过JDBC的DriverManagerDataSource或者BasicDataSource类来实例化一个数据源,应用程序就可以通过这个数据源来获取数据库连接。 总的来说,Apache DBCP是Java应用程序中实现数据库连接池的一个经典选择,它与...

    commons-dbcp.jar.rar

    数据库连接池是在应用服务器启动时预创建一定数量的数据库连接,并将这些连接保存在一个池中。当应用程序需要访问数据库时,不是直接创建新的连接,而是从池中获取一个已存在的连接;使用完毕后,连接会被归还到池中...

    DBCP 数据源jar包

    DBCP(Jakarta Commons DBCP)数据源是Apache软件基金会的一个开源项目,它提供了一个数据库连接池服务。在Java应用程序中,特别是那些基于Servlet容器(如Tomcat)的应用,DBCP是一个常用的数据库连接管理工具。它...

    dbcp的jar包

    DBCP(Database Connection Pool)是Apache组织提供的一个开源数据库连接池组件,主要包含在Apache Commons DBCP项目中。这个库允许开发者管理数据库连接,通过池化的方式提高应用程序的性能和效率。DBCP是一个基于...

    DBCP数据源实现.rar

    DBCP(Database Connection Pool)是Apache的一个开源项目,全称为Apache Commons DBCP,它提供了一个数据库连接池组件。在Java应用中,特别是在服务器端,为了提高数据库操作的性能和效率,通常会使用数据库连接池...

    DBCP需要的jar包

    DBCP(Database Connection Pool)是Apache Commons项目中的一个数据库连接池组件,全称为"Commons DBCP"。它提供了一种在Java应用程序中管理数据库连接的方法,通过池化技术来提高性能和效率。数据库连接池是应用...

    jdbc与dbcp数据库连接

    以下是一个简单的使用DBCP连接池的Java代码示例: ```java import org.apache.commons.dbcp2.BasicDataSource; public class JdbcDbcpExample { public static void main(String[] args) { // 初始化连接池 ...

    DBCP配置所需jar包(合)

    DBCP(Database Connection Pool)是Apache Commons项目中的一个数据库连接池组件,它的全称是Apache Commons DBCP。DBCP的主要功能是管理数据库连接,通过池化技术提高数据库操作的性能,减少创建和释放数据库连接...

    dbcp数据库连接池使用jar包

    DBCP数据库连接池的引入,使得应用程序可以预先创建并维护一定数量的数据库连接,当需要与数据库通信时,从连接池中获取一个已存在的连接,用完后不是立即关闭,而是将其归还回连接池,供后续使用。这样减少了频繁的...

    dbcp 1.2.2

    Apache Commons DBCP 1.2.2 是一个在Java应用程序中管理数据库连接池的开源库。这个版本的DBCP是Apache Commons项目的一部分,旨在提供一个健壮、高性能的数据库连接池实现,以提高Java应用的数据库访问效率。在本篇...

    commons-dbcp包资源

    Apache Commons DBCP(Database Connection Pool)是Apache软件基金会开发的一个开源项目,它提供了一个数据库连接池组件。数据库连接池在处理多用户并发访问时,能够有效地管理数据库连接,提高系统的性能和效率。...

Global site tag (gtag.js) - Google Analytics