DBCP(DataBase connection pool),数据库连接池。是 apache 上的一个 java 连接池项目,也是 tomcat 使用的连接池组件。单独使用dbcp需要3个包:commons-dbcp.jar,commons-pool.jar,commons-collections.jar。
由于建立数据库连接是一个非常耗时耗资源的行为,所以通过连接池预先同数据库建立一些连接,放在内存中,应用程序需要建立数据库连接时直接到连接池中申请一个就行,用完后再放回去。
【1】配置文件
#mysql db.className=com.mysql.jdbc.Driver #mysql to write wdb.url=jdbc:mysql:// wdb.username=root wdb.pwd=123456 wdb.maxActive=30 wdb.maxIdle=10 wdb.maxWait=3600000 #mysql common config info common.db.removeAbandoned=false common.db.removeAbandonedTimeout=120 common.db.testOnBorrow=true common.db.logAbandoned=true
【2】创建数据库连接池并获得数据库连接
package hhf.dbcp.util; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.Properties; import org.apache.commons.dbcp2.BasicDataSource; import org.apache.commons.dbcp2.BasicDataSourceFactory; /** * Get the connection from writing DB */ public class WDBConnUtils { private static BasicDataSource dataSource = null; public static void init() { if (dataSource != null) { try { dataSource.close(); } catch (Exception e) { e.printStackTrace(); } dataSource = null; } try { Properties p = new Properties(); p.setProperty("driverClassName", SystemConstants.DB_CLASS_NAME); p.setProperty("url", SystemConstants.W_DB_URL); p.setProperty("username", SystemConstants.W_DB_USER_NAME); p.setProperty("password", SystemConstants.W_DB_USER_PWD); p.setProperty("maxActive", SystemConstants.W_DB_MAX_ACTIVE); p.setProperty("maxIdle", SystemConstants.W_DB_MAX_IDLE); p.setProperty("maxWait", SystemConstants.W_DB_MAX_WAIT); p.setProperty("removeAbandoned", SystemConstants.DB_REMOVE_ABANDONED); p.setProperty("removeAbandonedTimeout", SystemConstants.DB_REMOVE_ABANDONED_TIMEOUT); p.setProperty("testOnBorrow", SystemConstants.DB_TEST_ONBORROW); p.setProperty("logAbandoned", SystemConstants.DB_LOG_ABANDONED); dataSource = (BasicDataSource) BasicDataSourceFactory.createDataSource(p); } catch (Exception e) { e.printStackTrace(); } } public static synchronized Connection getConnection() throws SQLException { if (dataSource == null) { init(); } Connection conn = null; if (dataSource != null) { conn = dataSource.getConnection(); conn.setAutoCommit(false); } return conn; } /** * 关闭资源 * @param conn * @param pstmt * @param rs */ public static void closeResources(Connection conn, PreparedStatement pstmt, ResultSet rs) { if (null != rs) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } finally { if (null != pstmt) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } finally { if (null != conn) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } } } } } } } /** * 关闭资源 * @param conn * @param pstmt */ public static void closeResources(Connection conn, PreparedStatement pstmt) { if (null != pstmt) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } finally { if (null != conn) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } } } } } }
【3】执行插入和查询操作
package hhf.dbcp.throughput; import hhf.dbcp.util.WDBConnUtils; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; /** * 数据库操作 * @author HHF * 2014年12月29日 */ public class InsertQueryDao { /** * 插入数据 * @param num */ public void save(String num) { String NEWS_INFO_INSERT = "INSERT INTO table(num) values(?)"; Connection conn = null; PreparedStatement pst = null; try { conn = WDBConnUtils.getConnection(); pst = conn.prepareStatement(NEWS_INFO_INSERT); pst.setString(1, num); pst.execute(); conn.commit(); } catch (SQLException e) { e.printStackTrace(); } finally { WDBConnUtils.closeResources(conn, pst); } } /** * 查询数据 * @param num * @return */ public String query(String num) { String NEWS_INFO_QUERY_LIST = "SELECT news_id FROM table num=? "; Connection conn = null; PreparedStatement pst = null; ResultSet rs = null; String result = null; try { conn = WDBConnUtils.getConnection(); pst = conn.prepareStatement(NEWS_INFO_QUERY_LIST); pst.setString(1, num); rs = pst.executeQuery(); while(rs.next()){ result = rs.getString("news_id"); } } catch (Exception e) { e.printStackTrace(); }finally{ WDBConnUtils.closeResources(conn, pst, rs); } return result; } }
【4】测试
public class Main { private static final Log log = LogFactory.getLog(Main.class); public void doProcess(String processTime1, String processTime2, int runMode) { InsertQueryDao dao = new InsertQueryDao(); String num = dao.query("0");//获得查询结果 log.info("num " + num); } }
(PS:附上项目测试源码和相关的jar包)
相关推荐
setting.xml文件,修改Maven仓库指向至阿里仓
基于java的玉安农副产品销售系统的开题报告
dev-c++ 6.3版本
基于java的项目监管系统开题报告
基于springboot多彩吉安红色旅游网站源码数据库文档.zip
毕业设计&课设_基于 AFLFast 改进能量分配策略的毕业设计项目,含 Mix Schedule策略设计及测试结果分析.zip
基于springboot办公用品管理系统源码数据库文档.zip
C++调用qml对象Demo
非常漂亮的类Web界面的Delphi设计54ed7-main.zip
VB SQL车辆管理系统是一款基于Visual Basic(VB)编程语言和SQL数据库开发的综合车辆管理工具。该系统集成了车辆信息管理、驾驶员信息管理、车辆调度、维修记录、数据存储与检索、报告生成以及安全权限管理等多个核心功能模块。 源代码部分提供了详细的开发流程和实现方法,涵盖了从数据库设计、界面设计到事件驱动编程、数据访问技术和错误处理等关键技术点。通过该系统,用户可以方便地录入、查询、修改和删除车辆及驾驶员信息,实现车辆信息的实时更新和跟踪。同时,系统还支持生成各类车辆管理相关的报告,帮助用户更好地掌握车辆运营情况。 系统部分则采用了直观易用的用户界面设计,使得用户能够轻松上手并快速完成车辆管理工作。系统还具备强大的数据处理能力和安全性,通过数据备份和系统升级优化等功能,确保数据的完整性和系统的稳定运行。 总体而言,VB SQL车辆管理系统是一款功能全面、易于操作且安全可靠的车辆管理工具,适用于企业和个人进行日常车辆运营和管理。无论是车辆信息的录入、查询还是报告生成,该系统都能够提供高效、便捷的服务,是车辆管理工作的理想选择。
AutoSAR基础学习资源
基于springboot英语学习平台源码数据库文档.zip
数据集,深度学习,密封数据集,马体态数据集
基于java的数字家庭网站开题报告
podman使用国内源镜像加速器
基于springboot+web的留守儿童网站源码数据库文档.zip
基于springboot的智能宾馆预定系统源码数据库文档.zip
GetQzonehistory-main.zip
环境说明:开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7 数据库工具:Navicat 开发软件:eclipse/myeclipse/idea Maven包:Maven 浏览器:谷歌浏览器。 项目经过测试均可完美运行
内容概要:本文档详细介绍了QST公司生产的QMI8A01型号的6轴惯性测量单元的数据表及性能参数。主要内容包括设备特性、操作模式、接口标准(SPI、I2C与I3C),以及各种运动检测原理和技术规格。文中还提到了设备的工作温度范围宽广,内置的大容量FIFO可用于缓冲传感器数据,减少系统功耗。此外,对于器件的安装焊接指导亦有详细介绍。 适合人群:电子工程技术人员、嵌入式开发人员、硬件设计师等。 使用场景及目标:适用于需要精准测量物体空间位置变化的应用场合,如消费电子产品、智能穿戴设备、工业自动化等领域。帮助工程师快速掌握该款IMU的技术要点和应用场景。 其他说明:文档提供了详细的电气连接图表、封装尺寸图解等资料,方便用户进行电路板的设计制作。同时针对特定应用提出了一些优化建议。