java cp30连接mysql数据库_JDBC利用C3P0数据库连接池连接数据库

JDBC之C3P0数据库连接池,供大家参考,具体内容如下

1 首先在src中创建c3p0-config.xml 配置文件,文件中内容如下(首先下载C3P0.jar工具包 并放入项目环境变量中)

com.mysql.jdbc.Driver

jdbc:mysql:localhost:3306/jdbc_01

root

root

5

10

5

100

2

5

2 创建一个工具类用于利用C3P0数据库连接池获得数据库连接 工具类如下

package cn.qhy.jdbc;

import java.io.IOException;

import java.lang.reflect.Field;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.ResultSetMetaData;

import java.sql.SQLException;

import java.sql.Statement;

import java.util.HashMap;

import java.util.Map;

import java.util.Map.Entry;

import javax.sql.DataSource;

import com.mchange.v2.c3p0.ComboPooledDataSource;

public class MyDBUtils {

private static DataSource dataSource;

static {// 静态代码块,只执行一次

dataSource = new ComboPooledDataSource("MySQL");

}

/**

*

* @return

* @throws SQLException

*/

public static Connection getConnection() throws SQLException {

return dataSource.getConnection();

}

/**

* 通用的用来关闭数据有关的所有的资源的操作

*/

public static void close(Connection conn, Statement sta, ResultSet re) {

if (re != null)

try {

re.close();

} catch (SQLException e) {

e.printStackTrace();

}

if (sta != null)

try {

sta.close();

} catch (SQLException e) {

e.printStackTrace();

}

if (conn != null)

try {

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

3 创建测试类,测试C3P0是否连接数据库(利用JUnit单元测试)

package cn.qhy.test;

import java.beans.PropertyVetoException;

import java.sql.Connection;

import java.sql.SQLException;

import org.junit.jupiter.api.Test;

import com.mchange.v2.c3p0.ComboPooledDataSource;

import cn.qhy.jdbc.MyDBUtils;

public class C3P0Test {

/**

* @throws SQLException

*

*/

@Test

public void c3p0xmlTest() throws SQLException {

Connection conn = MyDBUtils.getConnection();

System.out.println(conn);

conn.close();

}

}

结果如下

4618aa2b6a3fe4bb7c41045349b2a13c.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值