专栏首页Java技术分享圈杨校老师课堂之基于Apache的数据库连接池DBCP的工具类开发

杨校老师课堂之基于Apache的数据库连接池DBCP的工具类开发


1.编写工具类

package cn.javabs.school.util;

import org.apache.commons.dbcp.BasicDataSourceFactory;

import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

public class DbcpUtils {
    private  static DataSource dataSource;
    static  String  myFile = "dbcp.properties";

    static {
        try {
            InputStream resourceAsStream = DruidUtils.class.getClassLoader().getResourceAsStream(myFile);
            Properties p = new Properties();
            p.load(resourceAsStream);
            // 调用的核心类是BasicDataSourceFactory
            dataSource = BasicDataSourceFactory.createDataSource(p);
        } catch (Exception e) {
            throw  new RuntimeException(e);
        }
    }
    public static DataSource getDataSource(){
        return  dataSource;
    }

    public static Connection getConnection(){
        try {
            return  dataSource.getConnection();
        } catch (SQLException e) {
            throw  new RuntimeException(e);
        }
    }
}

2.编写配置文件:dbcp.properties

driverClassName = com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/0314
username=root
password=sorry

3.编写测试类:TestData

package cn.javabs.school.test;

import cn.javabs.school.entity.Admin;
import cn.javabs.school.util.DbcpUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.junit.Test;

import java.sql.SQLException;
import java.util.List;

/**
 * 测试类: 用于测试数据库是否通畅
 * @author Mryang
 */
public class TestData {

    QueryRunner  qr =  new QueryRunner(DbcpUtils.getDataSource());

    @Test
    public void fun(){
        try {
            Admin admin = new Admin();
            List<Admin> admins = qr.query("select * from admin", new BeanListHandler<Admin>(Admin.class));
            System.out.println(admins);
        } catch (SQLException e) {
            throw new RuntimeException("error:"+e);
        }
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 这就是我不建议去外包公司开发的原因?

    咱们每个人都是学了好久编程,做了好久的项目,目的也只是为了可以去一个不错的公司可以有一个不错前景的发展。

    杨校
  • 杨老师课堂之JavaEE三大框架Hibernate入门第一课

    杨校
  • 杨校老师课堂之Java项目部署到云端服务器之安装MySQL、Jdk、Tomcat

    杨校
  • Android向node.js编写的服务器发送数据并接收请求

    本文实例为大家分享了Android向node.js服务器发送数据并接收请求的具体代码,供大家参考,具体内容如下

    砸漏
  • xml与数据库中数据的导入导出

    这是我一个晚上做出来的,因为要去做其他的项目,所以只实现了对特定数据库的xml操作,不过我觉得这是学习xml挺不错的参考代码和文档

    SmileNicky
  • 网络编程

    TCP编程中,如果要完成通信,通信双方必须要创建 socket,通过 socket 完成通信。

    Carlos Ouyang
  • 离线网页制作器(beta1.0)

    1 package hhuarongdao; 2 /* 3 *使用方法: 先选择保存路径,然后输入相应的网址, 4 *然后会得到那个网页的离...

    Gxjun
  • java进阶|jdbc的用法

    大概是17年时用过jdbc进行操作数据库,到现在为止没有再用过jdbc去写过一个示例程序,即简单的增删改查操作,CRUD也不是那么容易写吧,后面就开始基...

    码农王同学
  • 进行JDBC操作时,连接参数的配置(附DBUtil工具类)

    时间静止不是简史
  • Java 读写大文本文件

    如下的程序,将一个行数为fileLines的文本文件平均分为splitNum个小文本文件,其中换行符’r’是linux上的,windows的java换行符是’...

    xiangzhihong

扫码关注云+社区

领取腾讯云代金券