一、导入Druid的jar包和数据库驱动jar包

二、定义配置文件

  与c3p0不同,Druid的配置文件是properties形式的。而且Druid不像c3p0那样可以自动加载配置文件,Druid需要手动去指定配置文件,所以Druid的配置文件可以叫任意名称,并且可以放置在任意目录下。

  1. # druid.properties文件的配置
  2. driverClassName=com.mysql.jdbc.Driver
  3. url=jdbc:mysql://127.0.0.1:3307/test_db
  4. username=root
  5. password=root
  6. # 初始化连接数量
  7. initialSize=5
  8. # 最大连接数
  9. maxActive=10
  10. # 最大超时时间
  11. maxWait=3000

目录结构如下:

  

三、使用Druid连接池

  1. package cn.xj.datasource.druid;
  2.  
  3. import com.alibaba.druid.pool.DruidDataSourceFactory;
  4.  
  5. import javax.sql.DataSource;
  6. import java.io.IOException;
  7. import java.io.InputStream;
  8. import java.sql.Connection;
  9. import java.util.Properties;
  10.  
  11. public class Druid_demo {
  12. public static void main(String[] args) throws Exception {
  13. //加载配置文件
  14. Properties pro = new Properties();
  15. InputStream is = Druid_demo.class.getClassLoader().getResourceAsStream("druid.properties");
  16. pro.load(is);
  17. //获取连接池对象
  18. DataSource ds = DruidDataSourceFactory.createDataSource(pro);
  19. //获取连接
  20. Connection conn = ds.getConnection();
  21. System.out.println(conn);
  22. }
  23. }

四、定义工具类

步骤:

  1.定义一个类JDBCUtils

    *类里边提供静态代码块加载配置文件,初始化连接池对象

    *类里边要提供这些方法:

      (1)获取连接方法:通过数据库连接池获取连接

      (2)释放资源

      (3)获取连接池的方法

  1. package cn.xj.datasource.utils;
  2.  
  3. import com.alibaba.druid.pool.DruidDataSourceFactory;
  4.  
  5. import javax.sql.DataSource;
  6. import java.io.IOException;
  7. import java.sql.Connection;
  8. import java.sql.ResultSet;
  9. import java.sql.SQLException;
  10. import java.sql.Statement;
  11. import java.util.Properties;
  12.  
  13. public class JDBCUtils {
  14. //定义成员变量
  15. private static DataSource ds;
  16.  
  17. static {
  18. try {
  19. //加载配置文件
  20. Properties pro = new Properties();
  21. pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties"));
  22. //获取连接池对象DataSource
  23. ds = DruidDataSourceFactory.createDataSource(pro);
  24. } catch (IOException e) {
  25. e.printStackTrace();
  26. } catch (Exception e) {
  27. e.printStackTrace();
  28. }
  29. }
  30.  
  31. //获取链接
  32. public static Connection getConnection() throws SQLException {
  33. return ds.getConnection();
  34. }
  35.  
  36. //释放资源
  37. public static void close(Statement stmt,Connection conn){
  38. if (stmt != null){
  39. try {
  40. stmt.close();
  41. } catch (SQLException e) {
  42. e.printStackTrace();
  43. }
  44. }
  45. if (conn != null){
  46. try {
  47. conn.close(); //归还连接
  48. } catch (SQLException e) {
  49. e.printStackTrace();
  50. }
  51. }
  52. }
  53.  
  54. public static void close(ResultSet rs,Statement stmt, Connection conn){
  55. if (rs != null){
  56. try {
  57. rs.close();
  58. } catch (SQLException e) {
  59. e.printStackTrace();
  60. }
  61. }
  62. if (stmt != null){
  63. try {
  64. stmt.close();
  65. } catch (SQLException e) {
  66. e.printStackTrace();
  67. }
  68. }
  69. if (conn != null){
  70. try {
  71. conn.close(); //归还连接
  72. } catch (SQLException e) {
  73. e.printStackTrace();
  74. }
  75. }
  76. }
  77.  
  78. //获取连接池方法
  79. public static DataSource getDateSource(){
  80. return ds;
  81. }
  82.  
  83. }

五、使用工具类      

  1. package cn.xj.datasource.druid;
  2.  
  3. import cn.xj.datasource.utils.JDBCUtils;
  4.  
  5. import java.sql.Connection;
  6. import java.sql.PreparedStatement;
  7. import java.sql.ResultSet;
  8. import java.sql.SQLException;
  9.  
  10. public class Druid_demo02 {
  11. public static void main(String[] args) {
  12. Connection conn = null;
  13. PreparedStatement pstmt = null;
  14. try {
  15. //获取连接
  16. conn = JDBCUtils.getConnection();
  17. //定义sql语句
  18. String sql = "insert into account value(null,?,?)";
  19. //获取PreparedStatement对象
  20. pstmt = conn.prepareStatement(sql);
  21. //给占位符(?)赋值
  22. pstmt.setString(1,"王五");
  23. pstmt.setDouble(2,3000);
  24. //执行sql语句
  25. int count = pstmt.executeUpdate();
  26. System.out.println(count);
  27. } catch (SQLException e) {
  28. e.printStackTrace();
  29. }finally {
  30. //释放资源
  31. JDBCUtils.close(pstmt,conn);
  32. }
  33. }
  34. }

  

Druid数据库连接池基本使用的更多相关文章

  1. Druid数据库连接池配置

    DRUID是阿里巴巴开源平台上一个数据库连接池实现,它结合了C3P0.DBCP.PROXOOL等DB池的优点,同时加入了日志监控,可以很好的监控DB池连接和SQL的执行情况,可以说是针对监控而生的DB ...

  2. Druid数据库连接池源码分析

    上一篇文章重点介绍了一下Java的Future模式,最后意淫了一个数据库连接池的场景.本想通过Future模式来防止,当多个线程同时获取数据库连接时各自都生成一个,造成资源浪费.但是忽略了一个根本的功 ...

  3. Spring Boot [使用 Druid 数据库连接池]

    导读 最近一段时间比较忙,以至于很久没有更新Spring Boot系列文章,恰好最近用到Druid, 就将Spring Boot 使用 Druid作为数据源做一个简单的介绍. Druid介绍: Dru ...

  4. Druid数据库连接池就这么简单

    前言 本章节主要讲解Druid数据库连接池,为什么要学Druid数据库连接池呢?? 我的知识储备数据库连接池有两种->C3P0,DBCP,可是现在看起来并不够用阿~当时学习C3P0的时候,觉得这 ...

  5. Druid 数据库连接池

    druid 数据库连接池 由阿里提供 步骤 1 导包 durid1.0.9 jar 包 2 定义配置文件 必须是 properties文件 名字任意 位置也任意 3 获得数据库连接池对象 通过 Dur ...

  6. 阿里druid数据库连接池配置

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...

  7. 【spring boot】15.spring boot项目 采用Druid数据库连接池,并启用druid监控功能

    在http://www.cnblogs.com/sxdcgaq8080/p/9039442.html的基础上,来看看spring boot项目中采用Druid连接池. GitHub地址:示例代码 == ...

  8. Spring Boot集成Druid数据库连接池

    1. 前言 Druid数据库连接池由阿里巴巴开源,号称是java语言中最好的数据库连接池,是为监控而生的.Druid的官方地址是:https://github.com/alibaba/druid 通过 ...

  9. 基于Druid数据库连接池的DBUtil工具类

    工具类 DruidUtil.java package com.zzuli.util; import com.alibaba.druid.pool.DruidDataSourceFactory; imp ...

  10. springboot2配置druid数据库连接池

    注意配置以下的依赖: <!-- 引入druid数据源--> <dependency> <groupId>com.alibaba</groupId> &l ...

随机推荐

  1. 易酷CMS2.5本地文件包含漏洞复现

    易酷CMS是一款影片播放CMS.该CMS2.5版本存在本地文件包含漏洞.我们可以利用这个漏洞,让其包含日志文件,然后再利用报错信息将一句话木马写入日志中.然后利用文件包含漏洞包含该日志文件,再用菜刀连 ...

  2. ADB调试工具的使用

    ADB(Android Debug Bridge)安卓调试桥,ADB工具是可以方便调试安卓应用的工具. ADB的安装 下载ADB工具,解压, 将ADB工具的目录加入系统环境变量中,打开CMD窗口,输入 ...

  3. Portswigger web security academy:Cross-site request forgery (CSRF)

    Portswigger web security academy:Cross-site request forgery (CSRF) 目录 Portswigger web security acade ...

  4. HBASE-使用问题-split region

    问题描述: HBASE表的管理以REGION分区为核心,通常面临如下几个问题: 1) 数据如何存储到指定的region分区,即rowkey设计,region splitkey设计 2)设计的split ...

  5. 混部之殇-论云原生资源隔离技术之CPU隔离(一)

    作者 蒋彪,腾讯云高级工程师,10+年专注于操作系统相关技术,Linux内核资深发烧友.目前负责腾讯云原生OS的研发,以及OS/虚拟化的性能优化工作. 导语 混部,通常指在离线混部(也有离在线混部之说 ...

  6. FTP文件上传

    一.配置FTP文件服务器 以Ubuntu为例 FTP两种模式简介 PORT(主动模式) 第一步FTP客户端首先随机选择一个大于1024的端口p1,并通过此端口发送请求连接到FTP服务器的21号端口建立 ...

  7. C++将数值转换为string

    std::to_string string to_string (int val); string to_string (long val); string to_string (long long ...

  8. Scrum Meeting 2

    Basic Info where:三号教学楼 when:2020/4/25 target: 简要汇报一下已完成任务,下一步计划与遇到的问题 Progress Team Member Position ...

  9. CocoaPods 构建自己的 Pod 库

    构建一个自己的库供其它人使用是不是一件很酷(苦)的事情,通过CocoaPods 可以快捷的构建自己库,并向全世界分享你的成果 一.创建 Podspec 有两种方式: 使用命令 pod lib crea ...

  10. istio sidecar流量处理机制及配置

    sidecar 介绍 在istio的流量管理等功能,都需要通过下发的配置应用到应用运行环境执行后生效,负责执行配置规则的组件在service mesh中承载应用代理的实体被称为side-car Ist ...