数据库连接池

连接池的概述

  1. 概念:其实就是一个容器(集合),存放数据库连接的容器。

    当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,

    从容器中获取连接对象,用户访问完之后,会将连接对象归还给容器。
  2. 好处:
    • 节约资源

      • 用户访问高效
  3. 实现:
    1. 标准接口:DataSource javax.sql包下的

      1. 方法:

        • 获取连接:getConnection()

          • 归还连接:Connection.close()。如果连接对象Connection是从连接池中获取的,那么调用Connection.close()方法,

            则不会再关闭连接了。而是归还连接
      2. 一般我们不去实现它,有数据库厂商来实现
        1. C3P0:数据库连接池技术
        2. Druid:数据库连接池实现技术,由阿里巴巴提供的
  4. C3P0:数据库连接池技术
    • 步骤:

      1. 导入jar包 (两个) c3p0-0.9.5.2.jar mchange-commons-java-0.2.12.jar ,

        • 不要忘记导入数据库驱动jar包
      2. 定义配置文件:
        • 名称: c3p0.properties 或者 c3p0-config.xml
        • 路径:直接将文件放在src目录下即可。
      3. 创建核心对象 数据库连接池对象 ComboPooledDataSource
      4. 获取连接: getConnection
    • 代码:

      //1.创建数据库连接池对象

      DataSource ds = new ComboPooledDataSource();

      //2. 获取连接对象

      Connection conn = ds.getConnection();
  5. Druid:数据库连接池实现技术,由阿里巴巴提供
    1. 步骤:

      1. 导入jar包 druid-1.0.9.jar
      2. 定义配置文件:
        • 是properties形式的
        • 可以叫任意名称,可以放在任意目录下
      3. 加载配置文件。Properties
      4. 获取数据库连接池对象:通过工厂来来获取 DruidDataSourceFactory
      5. 获取连接:getConnection
    • 代码:

      //3.加载配置文件

      Properties pro = new Properties();

      InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream("druid.properties");

      pro.load(is);

      //4.获取连接池对象

      DataSource ds = DruidDataSourceFactory.createDataSource(pro);

      //5.获取连接

      Connection conn = ds.getConnection();
    1. 定义工具类

      1. 定义一个类 JDBCUtils
      2. 提供静态代码块加载配置文件,初始化连接池对象
      3. 提供方法
        1. 获取连接方法:通过数据库连接池获取连接
        2. 释放资源
        3. 获取连接池的方法

      driverClassName=com.mysql.jdbc.Driver

      url=jdbc:mysql://127.0.0.1:3306/db3?useSSL=true

      username=root

      password=root

      initialSize=5

      maxActive=10

      maxWait=3000

      public class JDBCUtils {

        /**
      * 定义数据源
      */
      private static DataSource ds; static {
      try {
      /**
      * 加载配置文件
      */
      InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
      Properties pro = new Properties();
      pro.load(is);
      /**
      * 获取数据源
      */
      ds = DruidDataSourceFactory.createDataSource(pro); } catch (IOException e) {
      e.printStackTrace();
      } catch (Exception e) {
      e.printStackTrace();
      }
      } /**
      * 获取数据源
      * @return 返回数据源
      */
      public static DataSource getDataSource(){
      return ds;
      } /**
      * 获取连接对象
      * @return 返回连接对象
      * @throws SQLException 抛出的编译异常
      */
      public static Connection getConn() throws SQLException {
      return ds.getConnection();
      } /**
      * 关闭连接
      * @param stmt sql执行对象
      * @param conn 数据库连接对象
      */
      public static void close(Statement stmt, Connection conn){
      if(stmt != null){
      try {
      stmt.close();
      } catch (SQLException e) {
      e.printStackTrace();
      }
      } if(conn != null){
      try {
      conn.close();
      } catch (SQLException e) {
      e.printStackTrace();
      }
      }
      } /**
      * 关闭资源的重载方法
      * @param rs 处理结果集的对象
      * @param stmt 执行sql语句的对象
      * @param conn 连接数据库的对象
      */
      public static void close(ResultSet rs, Statement stmt, Connection conn){ if(rs != null){
      try {
      rs.close();
      } catch (SQLException e) {
      e.printStackTrace();
      }
      } if(stmt != null){
      try {
      stmt.close();
      } catch (SQLException e) {
      e.printStackTrace();
      }
      } if(conn != null){
      try {
      conn.close();
      } catch (SQLException e) {
      e.printStackTrace();
      }
      }
      }

      }

JdbcTemplate

  • Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发
  • 步骤:
    1. 导入jar包
    2. 创建JdbcTemplate对象。依赖于数据源DataSource
    • JdbcTemplate template = new JdbcTemplate(ds);
    1. 调用JdbcTemplate的方法来完成CRUD的操作
    • update():执行DML语句。增、删、改语句
    • queryForMap():查询结果将结果集封装为map集合,将列名作为key,将值作为value 将这条记录封装为一个map集合
      • 注意:这个方法查询的结果集长度只能是1
    • queryForList():查询结果将结果集封装为list集合
      • 注意:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中
    • query():查询结果,将结果封装为JavaBean对象
      • query的参数:RowMapper

        • 一般我们使用BeanPropertyRowMapper实现类。可以完成数据到JavaBean的自动封装
        • new BeanPropertyRowMapper<类型>(类型.class)
    • queryForObject:查询结果,将结果封装为对象
      • 一般用于聚合函数的查询

        public class SpringJdbcTemplateTest {

        private static JdbcTemplate jdbcTemplate;

         @Before
        public void init(){
        // 1. 导入jar包
        // 2. 创建JDBCTemplate对象
        jdbcTemplate = new JdbcTemplate(JdbcUtils.getDataSource());
        } @Test
        public void testInsert(){
        // 创建sql
        String sql = "INSERT INTO ACCOUNT VALUES(NULL,?,?)";
        // 执行sql,返回影响的行数
        int lines = jdbcTemplate.update(sql, "王五", 5000);
        System.out.println("影响的行数为:" + lines);
        } @Test
        public void testUpdate(){
        // 创建sql
        String sql = "UPDATE ACCOUNT SET BALANCE = ? WHERE ID = ?";
        // 执行sql,返回影响的行数
        int lines = jdbcTemplate.update(sql, 3000, 3);
        System.out.println("影响的行数为:" + lines);
        } @Test
        public void testDelete(){
        // 创建sql
        String sql = "DELETE FROM ACCOUNT WHERE ID = ?";
        // 执行sql,返回影响的行数
        int lines = jdbcTemplate.update(sql, 3);
        System.out.println("影响的行数为:" + lines);
        } @Test
        public void testQueryForMap(){
        // 3. 创建sql
        String sql = "SELECT * FROM STUDENT WHERE ID = ?";
        // 4. 使用查询语句进行查询(变长参数替换占位符)
        Map<String, Object> map = jdbcTemplate.queryForMap(sql,7);
        System.out.println(map);
        } @Test
        public void testQueryForList(){
        // 创建sql语句
        String sql = "SELECT * FROM STUDENT";
        // 执行sql,返回结果
        List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);
        // 处理结果
        for (Map<String, Object> map : list) {
        System.out.println(map);
        }
        } /**
        * queryForMap:将结果封装成Map,只能返回一条结果,
        * 列名为Key,对应的值为Value
        */
        @Test
        public void testQuery(){
        // 创建sql
        String sql = "SELECT * FROM ACCOUNT";
        // 执行sql(使用BeanPropertyRowMapper实现类。可以完成数据到JavaBean的自动封装)
        List<Account> accounts = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(Account.class));
        // 处理结果
        for (Account account : accounts) {
        System.out.println(account);
        }
        } @Test
        public void testQueryForObject(){
        // 创建sql
        String sql = "SELECT COUNT(ID) FROM ACCOUNT";
        // 执行sql,一般用于查询聚合函数()
        Long count = jdbcTemplate.queryForObject(sql,Long.class);
        System.out.println();
        }

        }

Java之JDBC连接池的更多相关文章

  1. Java中JDBC连接池&JDBCTemplate

    数据库连接池 概念:其实就是一个容器(集合),存放数据库连接的容器. 当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完之后,会将连接对象归 ...

  2. 四大流行的jdbc连接池之C3P0篇

    C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSourc ...

  3. Spring+SpringMVC+MyBatis+easyUI整合优化篇(九)数据层优化-jdbc连接池简述、druid简介

    日常啰嗦 终于回到既定轨道上了,这一篇讲讲数据库连接池的相关知识,线程池以后有机会再结合项目单独写篇文章(自己给自己挖坑,不知道什么时候能填上),从这一篇文章开始到本阶段结束的文章都会围绕数据库和da ...

  4. JDBC连接池-C池3P0连接

    JDBC连接池-C3P0连接 c3p0连接池的学习英语好的看英文原版      c3p0 - JDBC3 Connection and Statement Pooling 使用c3p0连接池  三种方 ...

  5. JDBC连接池(三)DBCP连接池

    JDBC连接池(三)DBCP连接池 在前面的随笔中提到 了  1.JDBC自定义连接池  2. C3P0连接池 今天将介绍DBCP连接池 第一步要导入jar包   (注意:mysql和mysql 驱动 ...

  6. JDBC连接池-自定义连接池

    JDBC连接池 java JDBC连接中用到Connection   在每次对数据进行增删查改 都要 开启  .关闭  ,在实例开发项目中 ,浪费了很大的资源 ,以下是之前连接JDBC的案例 pack ...

  7. Jmeter(九)JDBC连接池

    JDBC为java访问数据库提供通用的API,可以为多种关系数据库提供统一访问.因为SQL是关系式数据库管理系统的标准语言,只要我们遵循SQL规范,那么我们写的代码既可以访问MySQL又可以访问SQL ...

  8. jdbc连接池&改进dbUtil成C3P0Util

    一.jdbc连接池 1.连接池的存在理由   前面介绍的dbUtils工具类虽然实现了一个对jdbc的简单封装.但它依旧采取从驱动管理获取连接 (DriverManager.getConnection ...

  9. Tomcat 的 JDBC 连接池

    JDBC 连接池 org.apache.tomcat.jdbc.pool 是 Apache Commons DBCP 连接池的一种替换或备选方案. 那究竟为何需要一个新的连接池? 原因如下: Comm ...

随机推荐

  1. 【Unity Shader】Shader基础

    目录 Chapter3 Unity Shader 基础 Chapter3 Unity Shader 基础 概述 在Unity需要材质(Material)与Unity Shader配合使用来达到满意的效 ...

  2. 如何掌握 Kubernetes ?系统学习 k8s 的大纲一份

    深度剖析 Kubernetes 深度剖析 k8s 如何学习 Kubernetes ?如何入门 Kubernetes? 为了帮帮初学者,2018 年 InfoQ 旗下(就是你知道的那个 InfoQ 哇) ...

  3. 图片人脸检测(OpenCV版)

    图片人脸检测 人脸检测使用到的技术是OpenCV,上一节已经介绍了OpenCV的环境安装,点击查看. 功能展示 识别一种图上的所有人的脸,并且标出人脸的位置,画出人眼以及嘴的位置,展示效果图如下: 多 ...

  4. Redux和React-Redux的实现(一):Redux的实现和context

    react使用redux做状态管理,实现多个组件之间的信息共享,解决了父子组件.兄弟组件之间的复杂通信问题.vue有vuex,总之是一种flux的思想.react提供了react-redux这个库,一 ...

  5. Daily Scrum 11.14

    姓名 今日任务 黄新越 按照热度排序->产生柱状图 刘垚鹏 总体代码架构整合 王骜 总体代码架构整合 林旭鹏 优化整体UI布局 安康 优化整体UI布局 黄伟龙 预先合作编写测试用例 马佐霖 预先 ...

  6. Daily Scrum (2015/10/26)

    今晚由于我们组成员就团队Week5作业的个人贡献分开会协商,所以把今天的编码工作往后延迟了.考虑到有些成员代码还没理解够,正好TFS的代码阅读分配的工作时间还没进行完,所以在会议之后我们让成员回寝自由 ...

  7. 软工实践-Beta 冲刺 (6/7)

    队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 1.界面的修改与完善 展示GitHub当日代码/文档签入记 ...

  8. DPDK实例程序:testpmd

    用户手册:https://doc.dpdk.org/guides/testpmd_app_ug/index.html 还不错的入门:http://syswift.com/188.html 我的运行情况 ...

  9. SQLSERVER2017 最新补丁发布方式

    SQLSERVER2017 开始已经没有 SP service pack 包了. 取而代之的是CU 包 cumulative update 见: https://support.microsoft.c ...

  10. Logrotate还有谁记得它??

    我发现很多人的服务器上都运行着一些诸如每天切分Nginx日志之类的CRON脚本,大家似乎遗忘了Logrotate,争相发明自己的轮子,这真是让人沮丧啊!就好比明明身边躺着现成的性感美女,大家却忙着自娱 ...