Java建立数据库连接池
作者:网络转载 发布时间:[ 2016/12/13 11:08:43 ] 推荐标签:数据库 Java
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
try {
// 创建数据库连接库对象
ConnectionPoolUtil connPool = new ConnectionPoolUtil("com.mysql.jdbc.Driver",
"jdbc:mysql://127.0.0.1:3306/pool", "root", "root");
// 新建数据库连接库
connPool.createPool();
// SQL测试语句
String sql = "select * from pool";
// 设定程序运行起始时间
long start = System.currentTimeMillis();
// 循环测试100次数据库连接
for (int i = 0; i < 3; i++) {
Connection conn = connPool.getConnection(); // 从连接库中获取一个可用的连接
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(sql);
while (rs.next()) {
String name = rs.getString("userName");
System.out.println("查询结果" + name);
}
rs.close();
stmt.close();
connPool.returnConnection(conn); // 连接使用完后释放连接到连接池
}
System.out.println("经过100次的循环调用,使用连接池花费的时间:" + (System.currentTimeMillis() - start) + "ms");
// connPool.refreshConnections();//刷新数据库连接池中所有连接,即不管连接是否正在运行,都把所有连接都释放并放回到连接池。注意:这个耗时比较大。
connPool.closeConnectionPool();// 关闭数据库连接池。注意:这个耗时比较大。
// 设定程序运行起始时间
start = System.currentTimeMillis();
// 导入驱动
Class.forName("com.mysql.jdbc.Driver");
for (int i = 0; i < 100; i++) {
// 创建连接
Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/pool", "root", "root");
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(sql);
while (rs.next()) {
}
rs.close();
stmt.close();
conn.close();// 关闭连接
}
System.out.println("经过100次的循环调用,不使用连接池花费的时间:" + (System.currentTimeMillis() - start) + "ms");
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
本文内容不用于商业目的,如涉及知识产权问题,请权利人联系SPASVO小编(021-61079698-8054),我们将立即处理,马上删除。
相关推荐
Java性能测试有哪些不为众人所知的原则?Java设计模式??装饰者模式谈谈Java中遍历Map的几种方法Java Web入门必知你需要理解的Java反射机制知识总结编写更好的Java单元测试的7个技巧编程常用的几种时间戳转换(java .net 数据库)适合Java开发者学习的Python入门教程Java webdriver如何获取浏览器新窗口中的元素?Java重写与重载(区别与用途)Java变量的分类与初始化JavaScript有这几种测试分类Java有哪四个核心技术?给 Java开发者的10个大数据工具和框架Java中几个常用设计模式汇总java生态圈常用技术框架、开源中间件,系统架构及经典案例等
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11热门文章
常见的移动App Bug??崩溃的测试用例设计如何用Jmeter做压力测试QC使用说明APP压力测试入门教程移动app测试中的主要问题jenkins+testng+ant+webdriver持续集成测试使用JMeter进行HTTP负载测试Selenium 2.0 WebDriver 使用指南