maven mysql的jdbctemplate_Java中JDBC连接池&JDBCTemplate

数据库连接池

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

当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完之后,会将连接对象归还给容器。

好处:

节约资源

用户访问高效

实现:

标准接口:DataSource javax.sql包下的

方法:

获取连接:getConnection()

归还连接:Connection.close()。如果连接对象Connection是从连接池中获取的,那么调用Connection.close()方法,则不会再关闭连接了。而是归还连接

一般我们不去实现它,有数据库厂商来实现

1. C3P0:数据库连接池技术

2. Druid:数据库连接池实现技术,由阿里巴巴提供的

C3P0:数据库连接池技术

步骤:

1. 导入jar包 (两个) c3p0-0.9.5.2.jar mchange-commons-java-0.2.12.jar ,不要忘记导入数据库驱动jar包

e75663b1c0b3dac17a3ff279a36c0f3b.png

2. 定义配置文件:

名称: c3p0.properties 或者 c3p0-config.xml

路径:直接将文件放在src目录下即可。

ac00018ec185dc16ba1da4aa6e5c78e2.png

caefefd8adb2a546205e57ad210ea92f.png

3. 创建核心对象 数据库连接池对象 ComboPooledDataSource

4. 获取连接: getConnection

代码:

0079cb6d4b8cf62ace3627e17694dcb3.png

Druid:数据库连接池实现技术,由阿里巴巴提供的

步骤:

1. 导入jar包 druid-1.0.9.jar

37bb576492201766a92c9e4392da05a7.png

2. 定义配置文件:

是properties形式的,可以叫任意名称,可以放在任意目录下

d943390983c1b5bb758f48b6c5a65234.png

3. 加载配置文件。Properties

0787a4f74abe137b63a5f1fd5bb221d6.png

4. 获取数据库连接池对象:通过工厂来来获取 DruidDataSourceFactory

5. 获取连接:getConnection

9bfd79c0b941b8ea84099938af9e8fd6.png

代码:

011771eaa3e8f856c4cc10afaa4447ff.png

定义工具类

定义一个类 JDBCUtils

5a5fbc10b401a374301acc01031da0e3.png

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

e22b5089882e7d5d2963443ae9109626.png

提供方法

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

60c6c2d123f83d9325922a0627063f86.png

2. 释放资源

f10c0e6a1ea6002af1c529bbaf9c65ba.png

3. 获取连接池的方法

e3b88c02352382ffd205671c1e7d8487.png

Spring JDBC

Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发

步骤:

1. 导入jar包

bc5314845251263161b0749a66f8141c.png

2. 创建JdbcTemplate对象。依赖于数据源DataSource

JdbcTemplate template = new JdbcTemplate(ds);

3. 调用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:查询结果,将结果封装为对象,一般用于聚合函数的查询

代码:

9774bebae20d7d329f30fe97d5e82a38.png

Java之JDBC连接池

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

MySQL_(Java)【连接池】简单在JDBCUtils.java中创建连接池

MySQL_(Java)[事物操作]使用JDBC模拟银行转账向数据库发起修改请求 传送门 MySQL_(Java)[连接池]使用DBCP简单模拟银行转账事物 传送门 Java应用程序访问数据库的过程: ...

java中JDBC连接Oracle数据库

package com.xxxx.lunwen.test;import java.sql.*;public class DBUtil { static { try { // 加载Oracle驱动程序 ...

JAVA中JDBC连接Mysql数据库简单测试

一.引用库 maven库:mysql:mysql-connector-java:6.0.6 二.SDK环境 JAVA JDK10 三.测试代码 package com.mysql.mysqlconne ...

帆软报表FineReport中数据连接的JDBC连接池属性问题

连接池原理 在帆软报表FineReport中,连接池主要由三部分组成:连接池的建立.连接池中连接使用的治理.连接池的关闭.下面就着重讨论这三部分及连接池的配置问题. 1. 连接池原理 连接池技术的核心 ...

JDBC连接池。。。转载

1. 引言  近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及,计算机  应用程序已从传统的桌面应用转到Web应用.基于B/S(Browser/Server)架 ...

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

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

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

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

随机推荐

JavaScript 介绍

JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 ...

C#复习⑤

C#复习⑤ 2016年6月19日 22:39 Main Inheritance 继承 1.继承的语法结构 class A { // base class int a; public A() {...} ...

SqlHelper文件复习

SqlHelper这是个cs类文件,将经常使用到的数据库操作写到一个文件下,方便调用,以及减少代码量.使用这个文件的前提是要建立一个app.config文件,并且引用configuration程序集: ...

RMI

Java RMI (Remote Method Invocation 远程方法调用)是用Java在JDK1.1中实现的,它大大增强了Java开发分布式应用的能力.Java作为一种风靡一时的网络开发语言 ...

Spark0.8.0的安装配置

1.profile export SCALA_HOME=/home/hadoop/scala-2.9.3SPARK_080=/home/hadoop/spark-0.8.0export SPARK_H ...

(办公)SpringBoot与mybatisGenerator自动生成.

20181206-自动生成,少写一点代码. (以下的内容主要参考csdn上的这篇文章,还有简书上的mbatis- ...

Ubuntu的显示问题不全解决

首先我们安装的是Ubuntu 16.04版本.最开始一直不能解分辨率问题,导致信息显示不全 利用xrandr -s 1369x768(中间x是乘号不是英文字母) 命令来设置分辨率, 需注意的是: 1. ...

css 清除一些默认的设置

一.input标签的placeholder的设置 input::-webkit-input-placeholder{ /*WebKit browsers*/ //重置样式 } input::-moz- ...

实现卡片效果【DIV+CSS3】

一.文字卡片效果

meta文字卡片效果

hbase命名空间

在HBase中,namespace命名空间指对一组表的逻辑分组,类似于数据库,便于对表在业务上划分 HBase系统默认定义了两个缺省的namespace hbase:系统内建表,包括namespace ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值