JDBC连接池和DButils

【DBCP连接池工具类】

使用读取配置文件的方式

DBCP中有一个工厂类 BasicDataSourceFactory
工厂类中有一个静态方法

返回值为: DataSource createDataSource(Properties prop)

此方式返回的就是DataSource接口的实现类对象 BasicDataSource

创建properties集合+IO技术读取配置文件
把配置文件传入BasicDataSourceFactory 静态方法 createDataSource中

实现步骤:

1.创建properties集合+IO技术读取配置文件
2.使用类加载器,扫描包下的文件
InputStream 变量名 = DBCPUtilsReadConfig.class.getClassLoader().getResourceAsStream("传入配置文件名称")
3.创建properties集合
Properties prop = new Properties();
prop.load(is);
4.把配置文件传入 BasicDataSourceFactory静态方法 createDataSource中
DataSource 变量名= BasicDataSourceFactory.createDataSource(prpo)

【C3P0连接池的工具类】

连接规范接口 : java.sql.DataSource

接口的实现类对象 : ComboPooledDataSource

成员位置创建 : ComboPooledDataSource对象

实现代码: private static ComboPooledDataSource dataSource = new ComboPooledDataSource();

C3P0内部会自动扫描并解析xml文件,给ComboPooledDataSource设置数据量的四大信息

创建一个返回ComboPooledDataSource的方法

public static DataSource getDataSource(){
return dataSource;
}

创建一个静态方法返回Connection对象

实现代码: public static Connection getConnection(){
try {
return dataSource.getConnection();
} catch (SQLException e) {
throw new RuntimeException("获取数据库连接信息失败!");
}
}

创建一个静态方法释放资源

【DBUtils工具类】

DBUtils工具类作用:简化JDBC的发开(六步)

DBUtils有3个核心类

1.QueryRunner : 使用QueryRunner中的方法对数据库进行增删改查

2.DbUtils : 提供了大量的释放资源的方法

3.ResultSetHandler接口 : 提供了处理查询结果集的方法

●QueryRunner 类 :

构造方法: QueryRunner() 空参数构造方法

调用跟新和查询方法的时候,需要传入Connection对象

QueryRunner( DataSource ds) 带DataSource数据库连接池的构造方法

调用跟新和查询方法的时候QueryRunner会自动从DataSource实现类对象中获取数据库连接对象,使用完毕后自动归还.

成员方法: 执行增删改的成员方法

返回值: int update(Connection conn , String sql ,Object ... params) 用来执行增删改的SQL

返回值: int update(String sql , Object ... params) 用来执行增删改的SQL

参数 :

Connection conn : 数据库连接对象

String sql : 拼接的sql语句,可以使用 ? 占位符

Object...params : ?占位符的实际参数,可以使用Object[]
返回值: int 执行的有效行数

执行查询的成员方法:

返回值 : <T> T query(Connection conn , String sql , ResultSetHandier<T> rsh , Object...params)

<T> T query(String sql , ResultSetHandler<T> rsh , Object ... params)

参数: Connection conn : 数据库连接对象

String sql:拼接的sql语句,可以使用?占位符

Object...params : ?占位符的实际参数,可以使用Object[]

ResulSetHasndier<T> rsh : 用来存储查询之后的结果集,可以传入ResulSetHasndier 9种实现类对象

返回值 : <T> T :传入的ResltSetHandler实现类不同,返回的结果集也不同,使用泛型,传入什么结果集,就返回对应的类型

我的学习之路_第二十一章_JDBC连接池的更多相关文章

  1. 我的学习之路_第二十三章_HTML

    Html : 超级文本语言 ( Hyper text Markup Language ) HTML 文件扩展名是 * .html HTML 结构都是有标签组成 通常情况下标签有开始标签和结束标签组成 ...

  2. 我的学习之路_第二十七章_jQuery

    jQueryjs类库 把常用对象或者方法封装起来,让我们写代码效率更高 1.jQuery 2.extjs [jQuery入门] jQuery的引入: 通过script标签的src属性引入 入门: 获取 ...

  3. 我的学习之路_第二十章_JDBC

    JDBC 使用JDBC技术,通过mysql提供的驱动程序,操作数据库 ● 1. 注册驱动 告知jvm 使用的是什么驱动程序(mysql,oracle) 使用API中的类 DriverManager中的 ...

  4. 我的学习之路_第二十五_javaScript

    Javascript 作用:可以对表单数据进行校验,可以对页面实现一些动态效果 定义: JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型. 它的解释器被称为 ...

  5. 我的学习之路_第二十八章_JQuery 和validator插件

    jQuery 利用jQuery进行遍历 js原生: for(var i=0;i>?;i++){ } jQuery: 方式一: 想要遍历的jQuery对象.each(function(index, ...

  6. 我的学习之路_第二十九章_bootstrap

    bootstrap 内置了html,css,js插件为一体的前端框架 响应式布局: 设计一套页面就可以使用于很多现实设备 bootstrap: 1.入门(响应式布局的容器) 1.先进入jQuery的j ...

  7. 我的学习之路_第五章_Data,正则

    Date 类 (时间类) 所属包:java.util.Date 构造方法: public Date() 返回的是当前时间 也就是1970-1-1到电脑目前的时间值,用毫秒来表示 public Date ...

  8. Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第二十一章:环境光遮蔽(AMBIENT OCCLUSION)

    原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第二十一章:环境光遮蔽(AMBIENT OCCLUSION) 学习目标 ...

  9. “全栈2019”Java多线程第二十一章:同步代码块产生死锁的例子

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

随机推荐

  1. TCP协议总结

    TCP的特性 TCP提供一种面向连接的.可靠的字节流服务 在一个TCP连接中,仅有两方进行彼此通信.广播和多播不能用于TCP TCP使用校验和,确认和重传机制来保证可靠传输 TCP给数据分节进行排序, ...

  2. hosts文件原理

    hosts文件是一个用于储存计算机网络中各节点信息的计算机文件.这个文件负责将主机名映射到相应的IP地址.hosts文件通常用于补充或取代网络中DNS的功能.和DNS不同的是,计算机的用户可以直接对h ...

  3. GROUP BY语句与HAVING语句的使用

    一.GROUP BY GROUP BY语句用来与聚合函数(aggregate functions such as COUNT, SUM, AVG, MIN, or MAX.)联合使用来得到一个或多个列 ...

  4. RabbitMQ学习-1

    转载自:http://blog.csdn.net/anzhsoft/article/details/19563091. 1. 历史 RabbitMQ是一个由erlang开发的AMQP(Advanced ...

  5. win10+ubuntu17.04双系统安装与卸载(uefi+gpt)及常见软件安装

    换了台笔记本,重新装了下系统.配置是i7 6700hq+gtx965m,重装了下双系统. 之前老机器是大一时候买的,装得是win7+ubuntu19.04(mbr+bios).新机器到手,想法是装了w ...

  6. 【PHP】文件写入和读取详解

    文章提纲: 一.实现文件读取和写入的基本思路 二.使用fopen方法打开文件 三.文件读取和文件写入操作 四.使用fclose方法关闭文件 五.文件指针的移动 六.Windows和UNIX下的回车和换 ...

  7. EntityFramework6.X 之DbContex

    DbContext 数据库上下文DbContext是ObjectContext代表之一负责管理在运行时从数据库取数据.跟踪数据库的变更.对实体类映射到数据中持久化操作等,表示工作单元和存储库模式的组合 ...

  8. 四、 添加模型Model(ASP.NET MVC5 系列)

    在这一章节中我们将添加一些classes类来管理数据库中的movies.这些classes类就是ASP.NET MVC应用程序中的"model". 我们将用.NET框架中的数据访问 ...

  9. 解决shiro和quartz2 版本冲突问题

    修改build.gradle   compile ("org.quartz-scheduler:quartz:2.2.3") compile ("org.apache.s ...

  10. sort命令详解

    1.工作原理: sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出. [rocrocket@rocrocket programmi ...