SQL之数据库连接池与spring jdbc

简介: SQL之数据库连接池与spring jdbc

学习数据库连接池和spring jdbc可以简化jdbc原始代码

数据库连接池的概念

数据库连接池就是一个容器(集合),存放数据库连接对象的容器

当系统初始化之后(Tomcat服务器启动),容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,直接从容器中获取连接对象(无需再跟数据库创建连接),用户访问完之后,会将连接对象归还给容器

好处

  1. 节约资源
  2. 用户访问高效

实现

  1. 标准接口:DataSource
  1. 方法:
    获取连接:getConnection()
    归还连接:Connection.close()。如果连接对象Connection是从连接池中获取的,那么Connection.close()不再是关闭资源,而是归还连接至数据库连接池
  1. 一般我们不去实现它,由数据库厂商来实现
    Druid:数据库连接池实现技术,由阿里巴巴提供

Druid数据库连接池

步骤:

  1. 导入jar包
  2. 定义配置文件
    druid.properties
    可以叫任意名称,可以放在任意目录下,需要手动加载
  3. 加载配置文件
  4. 获取数据库连接池对象:通过工厂类来获取 DruidDataSourceFactory.createDataSource()
  5. 获取连接:getConnection

driverClassName=com.mysql.cj.jdbc.Driver

url=jdbc:mysql://localhost:3306/contest?serverTimezone=GMT%2B8&useSSL=false

username=username

password=password

# 初始化连接数量

initialSize=5

# 最大连接数

maxActive=10

# 最大等待时间

maxWait=3000

publicclassDruid {

   publicstaticvoidmain(String[] args) throwsException {

       //1.导入jar包

       //2.定义配置文件

       //3.加载配置文件

       Propertiespro=newProperties();

       InputStreamis=Druid.class.getClassLoader().getResourceAsStream("druid.properties");

       pro.load(is);

       //4.获取连接池对象

       DataSourceds=DruidDataSourceFactory.createDataSource(pro);

       //5.获取连接

       Connectioncoon=ds.getConnection();

       System.out.println(coon);

   }

}

Druid连接池的工具类

packageutils;

importcom.alibaba.druid.pool.DruidDataSourceFactory;

importjdbc.Druid;

importjavax.sql.DataSource;

importjava.io.InputStream;

importjava.sql.*;

importjava.util.Properties;

/**

* druid连接池的工具类

*/

publicclassJDBCUtils {

   //定义数据库连接池

   privatestaticDataSourceds;

   /**

    * 当类被加载时,初始化数据库连接池

    */

   static{

       try {

           //加载配置文件

           Propertiespro=newProperties();

           InputStreamis=Druid.class.getClassLoader().getResourceAsStream("druid.properties");

           pro.load(is);

           //获取连接池对象

           ds=DruidDataSourceFactory.createDataSource(pro);

       } catch (Exceptione) {

           e.printStackTrace();

       }

   }

   /**

    * 获取连接

    */

   publicstaticConnectiongetConnection() throwsSQLException {

       returnds.getConnection();

   }

   /**

    * 释放资源

    */

   publicstaticvoidclose(Connectionconn, Statementstmt,ResultSetrs){

       if(rs!=null){

           try {

               rs.close();

           } catch (SQLExceptionthrowables) {

               throwables.printStackTrace();

           }

       }

       if(stmt!=null){

           try {

               stmt.close();

           } catch (SQLExceptionthrowables) {

               throwables.printStackTrace();

           }

       }

       if(conn!=null){

           try {

               conn.close();

           } catch (SQLExceptionthrowables) {

               throwables.printStackTrace();

           }

       }

   }

   publicstaticvoidclose(Connectionconn, Statementstmt){

       close(conn,stmt,null);

   }

   

   /**

    * 获取数据库连接池

    */

   publicstaticDataSourcegetDataSource(DataSourceds){

       returnds;

   }

}

Spring JDBC

spring框架对jdbc进行了简单封装。提供一个JDBCTemplate对象简化JDBC的开发template:模板;即jdbc模板

jdbcTemplate内部对申请连接,释放资源等做了封装,我们不需要再去关心,只需要考虑如何定义SQL语句,如何执行及如何处理结果即可,大大简化jdbc的操作,很nice

步骤

  1. 导入jar包
  2. 创建JdbcTemplate对象。依赖于数据库连接池DataSource
    JdbcTemplate template = new JdbcTemplate(ds);
  3. 调用JdbcTemplate的方法来完成crud操作
  1. update():执行DML语句。增删改语句
  2. queryForMap():查询结果并封装为map集合
    注意:查询结果集长度只能为1(只能封装一行数据)
  3. queryForList():查询结果并封装为list集合
    注意:将每一行数据封装为一个map集合,再将map集合装载到list集合中
  4. query():查询结果并封装为Javabean对象(封装为数据库表的实体类的对象)
    注意:query的参数:RowMapper
    一般我们使用BeanPropertyRowMapper实现类。可以完成数据到javabean的自动封装
    new BeanPropertyRowMapper<类型>(类型.class)
  5. queryForObject():查询结果并封装为对象注意
  1. 如果要实现使用queryForObject获得自定义的类的对象,需要使用和方法query()相似的重载方法queryForObject(String sql, RowMapper<T> rowMapper, @Nullable Object... args)

template.queryForObject(sql, newBeanPropertyRowMapper<E>(E.class));

  1. 一般用于聚合函数的查询

/**

* 操作数据库中user表的类

* dao:database access object 数据库访问对象

*/

publicclassUserDao {

   //声明jdbcTemplate对象共用

   privateJdbcTemplatetemplate=newJdbcTemplate(JDBCUtils.getDataSource());

   /**

    * 登录方法

    * @param loginUser 只有用户名和密码

    * @return user 用户全部数据,没有返回null

    */

   publicUserlogin(UserloginUser){

       try {

           //1.定义SQL

           Stringsql="select * from user where username=? and password=?";

           //2.调用query方法

           Useruser=template.queryForObject(sql, newBeanPropertyRowMapper<User>(User.class),loginUser.getUsername(),loginUser.getPassword());

           returnuser;

       } catch (DataAccessExceptione) {

           returnnull;

       }

   }

}


目录
相关文章
|
1月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
171 3
|
17天前
|
SQL Java 数据库连接
[SQL]SQL注入与SQL执行过程(基于JDBC)
本文介绍了SQL注入的概念及其危害,通过示例说明了恶意输入如何导致SQL语句异常执行。同时,详细解释了SQL语句的执行过程,并提出了使用PreparedStatement来防止SQL注入的方法。
38 1
|
21天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
16 2
|
27天前
|
SQL Java 数据库
Spring Boot与Flyway:数据库版本控制的自动化实践
【10月更文挑战第19天】 在软件开发中,数据库的版本控制是一个至关重要的环节,它确保了数据库结构的一致性和项目的顺利迭代。Spring Boot结合Flyway提供了一种自动化的数据库版本控制解决方案,极大地简化了数据库迁移管理。本文将详细介绍如何使用Spring Boot和Flyway实现数据库版本的自动化控制。
25 2
|
1月前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
57 11
|
1月前
|
SQL 监控 数据库
慢SQL对数据库写入性能的影响及优化技巧
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生显著的不利影响
|
1月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
1月前
|
SQL 存储 数据可视化
SQL 数据库大揭秘:连接数字世界的魔法桥梁
在数字化时代,数据如繁星般璀璨,而 SQL 数据库则像强大的引力场,有序汇聚、整理和分析这些数据。SQL 数据库是一个巨大的数字宝库,装满各行各业的“宝藏”。本文将带你探索 SQL 数据库在电商、金融、医疗和教育等领域的应用。例如,在电商中,它能精准推荐商品;在金融中,它是安全卫士,防范欺诈;在医疗中,它是健康管家,管理病历;在教育中,则是智慧导师,个性化教学。此外,还将介绍如何利用板栗看板等工具实现数据可视化,提升决策效率。
|
1月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
56 3
|
28天前
|
SQL 数据库
SQL数据库基础语法入门
[link](http://www.vvo.net.cn/post/082935.html)