获得数据库连接池中数据连接资源的两种方式

相比于从数据库中直接获取数据库连接,使用数据库连接池的方式可以很大程度的提高数据库连接的效率。因此我们在实际开发中通常会采用数据库连接池的方式获取数据库的连接,在使用完成后这些资源再返还给数据库连接池。下面我们就来看一看常用的数据库连接池的简单的方法。


使用DBCP方式



话不多说,直接上代码。这里仅仅是一个简单的效果呈现,所以只需要打印出一句话即可。

package jdbcpool;

import java.sql.Connection;

import org.apache.commons.dbcp.BasicDataSource;
/**
 * 采用dbcp方式获得数据库连接池中的数据连接
 * @author Summer
 *
 */
public class Demo1 {

    @org.junit.Test
    public void Test() throws Exception {
        BasicDataSource bds = new BasicDataSource();
        bds.setDriverClassName("com.mysql.jdbc.Driver");
        bds.setUrl("jdbc:mysql://localhost:3306/test");
        bds.setUsername("root");
        bds.setPassword("mysql");
        try{
            Connection conn = bds.getConnection();
            System.out.println(conn);
        }catch(Exception e){
            throw new RuntimeException(e);
        }
    }

}

采用c3p0方式


package jdbcpool;

import java.sql.Connection;

import org.junit.Test;

import com.mchange.v2.c3p0.ComboPooledDataSource;

/**
 * 采用c3p0方式获得数据库连接池中的数据连接
 * @author Summer
 *
 */
public class Demo2 {
    @Test
    public void test() throws Exception {
        ComboPooledDataSource cpds = new ComboPooledDataSource();
        cpds.setDriverClass("com.mysql.jdbc.Driver");
        cpds.setJdbcUrl("jdbc:mysql://localhost:3306/test");
        cpds.setUser("root");
        cpds.setPassword("mysql");

        Connection conn = cpds.getConnection();
        System.out.println(conn);

    }

}

两种方式的小总结



这两种方式都是实际开发中使用的数据库连接池开源技术。但是这两者有各自的优点及用途。一般来说在使用Hibernate框架的时候会采用c3p0方式。而使用Spring框架的时候通常会采用dbcp的方式。不能说二者孰优孰劣,我们要在实际的开发中选择合适的即可。

时间: 2024-07-28 21:55:14

获得数据库连接池中数据连接资源的两种方式的相关文章

用excel高级筛选中选择不重复记录两种方式的差异图解

  excel中高级筛选中选择不重复记录两种方式的差异 高级筛选分为两种方式 在原有区域显示筛选结果 将筛选结果复制到其他位置 在原有区域显示筛选结果被筛选掉的行只是被隐藏了 第二种方式 将筛选结果复制到其他位置 被筛选掉的行已经是被删除的 选中数据区域 观察这个数据区域中有两个行是有重复的 并且分别出现过两次 而且是挨着的 鼠标点按a1单元格 拖动鼠标到e25单元格 松开鼠标 点击菜单栏 数据 筛选 高级筛选命令 在弹出的高级筛选对话框的方式 选择为将筛选结果复制到其他位置 点击复制位置后面的

php连接MySQL的两种方式对比_Mysql

记录一下PHP连接MySQL的两种方式. 先mock一下数据,可以执行一下sql. /*创建数据库*/ CREATE DATABASE IF NOT EXISTS `test`; /*选择数据库*/ USE `test`; /*创建表*/ CREATE TABLE IF NOT EXISTS `user` ( name varchar(50), age int ); /*插入测试数据*/ INSERT INTO `user` (name, age) VALUES('harry', 20), ('

ajax中data传参的两种方式分析

本文实例讲述了ajax中data传参的两种方式.分享给大家供大家参考,具体如下: 1. POST方式: /** * 订单取消 * @return {Boolean} 处理是否成功 */ function orderCancel(orderId, commant){ var flag = false; $.ajax({ type: "POST", url: "../order/orderCancel.action", //orderModifyStatus data:

ajax中data传参的两种方式分析_AJAX相关

本文实例讲述了ajax中data传参的两种方式.分享给大家供大家参考,具体如下: 1. POST方式: /** * 订单取消 * @return {Boolean} 处理是否成功 */ function orderCancel(orderId, commant){ var flag = false; $.ajax({ type: "POST", url: "../order/orderCancel.action", //orderModifyStatus data:

详解Android提交数据到服务器的两种方式四种方法_Android

Android应用开发中,会经常要提交数据到服务器和从服务器得到数据,本文主要是给出了利用http协议采用HttpClient方式向服务器提交数据的方法. 代码比较简单,这里不去过多的阐述,直接看代码. /** * @author Dylan * 本类封装了Android中向web服务器提交数据的两种方式四种方法 */ public class SubmitDataByHttpClientAndOrdinaryWay { /** * 使用get请求以普通方式提交数据 * @param map 传

详解Android提交数据到服务器的两种方式四种方法

Android应用开发中,会经常要提交数据到服务器和从服务器得到数据,本文主要是给出了利用http协议采用HttpClient方式向服务器提交数据的方法. 代码比较简单,这里不去过多的阐述,直接看代码. /** * @author Dylan * 本类封装了Android中向web服务器提交数据的两种方式四种方法 */ public class SubmitDataByHttpClientAndOrdinaryWay { /** * 使用get请求以普通方式提交数据 * @param map 传

实战分析快速获取有效外链资源的两种方式

其实现在有很多的地方都可以获取外链,但是还是有很多的朋友在问怎么获取外链资源,有哪些地方可以发外链,徐国祥其实前面分享过很多的外链资源,其中海多外链资源V4这个软件里面包含了各种各样的外链资源,以及无需审核的29个交换链接平台都可以算作外链资源,但是很多朋友反应海多软件里面很多的资源都已经失效了,而且也不能保证收录,那么怎么样才能快速获取有效外链资源,这里徐国祥和大家分享下自己如何快速获取的有效外链资源的二种方式: 1.分析其他的网站的外链资源 这个我相信大家都会,而且我们一般都是去分析竞争对手

获取有效外链资源的两种方式

1.分析其他的网站的外链资源 这个我相信大家都会,而且我们一般都是去分析竞争对手的网站,那我们分析过对手的外链情况,自己利用过没有呢,我估计很多的朋友都是分析过,没有去利用,还是按照自己的找外链资源的方式去做自己的外链,下面以我自己的网站外链为例说明下   大家可以看到我的外链有seowhy,aspcms,问问,csdn,宝盒网,这是都是已经证明可以收录了,同样你也可以去做啊,你多分析一些网站,你就会得到很多有效的收录的外链网址资源,比你去问朋友强多了,别人给的还不知道收录不,而且你自己找的都是

ASP与ACCESS连接的常用两种方式

<%     dim dd,connstr     dd="data.mdb"    connstr="provider=microsoft.jet.oledb.4.0;data source=" & server.mappath (""&dd&"")     set bb=server.createobject ("adodb.connection")     bb.open