java中DriverManager跟DataSource获取getConnection有什么不同?

数据库连接与连接池技术详解
本文深入探讨了数据库连接管理的重要性和优化方法,详细介绍了datasource与DriverManager的区别,阐述了连接池技术如c3p0和DBCP的作用与实现原理。重点解释了DataSource接口在简化数据库连接过程中的关键作用,以及JDK API提供的不同类型DataSource实现的特点。同时,文章还对比了四种连接数据库的方式,旨在提高开发者对数据库连接与管理的理解。

1、datasource是与连接池获取连接,而DriverManager是获取与数据库的连接!

DriverManager类的主要作用是管理注册到DriverManager中的JDBC驱动程序,并根据需要使用JDBC驱动程序建立与数据服务器的网络连接。但是建立与数据库的连接是一项较耗资源的工作,频繁的进行数据库连接建立操作会产生较大的系统开销,为了解决上述问题,可以采用数据库连接池技术。

 

2、datasource内部封装了 DriverManager的使用。。。 
DataSource主要是为了方便配置使用。。。 作为OO概念上也需要有这个类和对象来表示数据的来源。。。


3、c3p0 是一个连接池 同样常用还有DBCP 。。。其相关概念是JDBC中的Connection。。。
还有就是POSA第三卷中的 POOL这个模式概念。。。。
简单的说就是为了复用Connection而出现的一个工具,作用是自动缓存连接资源。

底层实现都是一样的,就是使用了池化概念,如对象池,线程池。
就是先把材料都准备好再开工,所有连接在服务启动之初就初始化好了,用完之后不销毁,等待下一次使用
有点像缓存技术。

 

4、 jdk api解释

public interface DataSourceextends CommonDataSource, Wrapper

该工厂用于提供到此 DataSource 对象所表示的物理数据源的连接。作为 DriverManager 工具的替代项,DataSource 对象是获取连接的首选方法。实现 DataSource 接口的对象通常在基于 JavaTM Naming and Directory Interface (JNDI) API 的命名服务中注册。

DataSource 接口由驱动程序供应商实现。共有三种类型的实现

  1. 基本实现 - 生成标准的 Connection 对象

  2. 连接池实现 - 生成自动参与连接池的 Connection 对象。此实现与中间层连接池管理器一起使用。

  3. 分布式事务实现 - 生成一个 Connection 对象,该对象可用于分布式事务,大多数情况下总是参与连接池。此实现与中间层事务管理器一起使用,大多数情况下总是与连接池管理器一起使用。

DataSource 对象的属性在必要时可以修改。例如,如果将数据源移动到另一个服务器,则可更改与服务器相关的属性。其优点在于,由于可以更改数据源的属性,所以任何访问该数据源的代码都无需更改。

通过 DataSource 对象访问的驱动程序本身不会向 DriverManager 注册。通过查找操作获取 DataSource 对象,然后使用该对象创建 Connection 对象。使用基本的实现,通过 DataSource 对象获取的连接与通过 DriverManager 设施获取的连接相同。

 

参考:http://bbs.youkuaiyun.com/topics/300234840

扩展:四种连接数据库的方法(DriverManager、DataSource子类、DBCP、c3p0)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值