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

11113fsfasdfasdfa 2009-04-30 09:42:38
如题 同样是获取连接,这两种方法有什么区别?
还有大并发的事情是web服务器做的还是像hibernate中的c3p0这样的东西做的?
...全文
2853 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
quickTang 2011-03-04
  • 打赏
  • 举报
回复
这玩意好底层
mingtian525 2009-12-25
  • 打赏
  • 举报
回复
拷贝于JDK 6.0 中文版.
--------------------------------------
public interface DataSource extends CommonDataSource, Wrapper
该工厂用于提供到此 DataSource 对象所表示的物理数据源的连接。作为 DriverManager 工具的替代项,DataSource 对象是获取连接的首选方法。实现 DataSource 接口的对象通常在基于 JavaTM Naming and Directory Interface (JNDI) API 的命名服务中注册。

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

基本实现 - 生成标准的 Connection 对象
连接池实现 - 生成自动参与连接池的 Connection 对象。此实现与中间层连接池管理器一起使用。
分布式事务实现 - 生成一个 Connection 对象,该对象可用于分布式事务,大多数情况下总是参与连接池。此实现与中间层事务管理器一起使用,大多数情况下总是与连接池管理器一起使用。
DataSource 对象的属性在必要时可以修改。例如,如果将数据源移动到另一个服务器,则可更改与服务器相关的属性。其优点在于,由于可以更改数据源的属性,所以任何访问该数据源的代码都无需更改。

通过 DataSource 对象访问的驱动程序本身不会向 DriverManager 注册。通过查找操作获取 DataSource 对象,然后使用该对象创建 Connection 对象。使用基本的实现,通过 DataSource 对象获取的连接与通过 DriverManager 设施获取的连接相同。
----------------------------------------------
public class DriverManager extends Object
管理一组 JDBC 驱动程序的基本服务。
注:DataSource 接口是 JDBC 2.0 API 中的新增内容,它提供了连接到数据源的另一种方法。使用 DataSource 对象是连接到数据源的首选方法。

作为初始化的一部分,DriverManager 类会尝试加载在 "jdbc.drivers" 系统属性中引用的驱动程序类。这允许用户定制由他们的应用程序使用的 JDBC Driver。
在调用 getConnection 方法时,DriverManager 会试着从初始化时加载的那些驱动程序以及使用与当前 applet 或应用程序相同的类加载器显式加载的那些驱动程序中查找合适的驱动程序。
深夜情感老师 2009-05-31
  • 打赏
  • 举报
回复
都是高手啊,学习了
liggway 2009-05-31
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 wfeng007 的回复:]
datasource内部封装了 DriverManager的使用。。。
DataSource主要是为了方便配置使用。。。 作为OO概念上也需要有这个类和对象来表示数据的来源。。。


c3p0 是一个连接池 同样常用还有DBCP 。。。其相关感念是JDBC中的Connection。。。
还有就是POSA第三卷中的 POOL这个模式概念。。。。
简单的说就是为了复用Connection而出现的一个工具,作用是自动缓存连接资源。
[/Quote]
是的,底层实现都是一样的,就是使用了池化概念,如对象池,线程池。
就是先把材料都准备好再开工,所有连接在服务启动之初就初始化好了,用完之后不销毁,等待下一次使用
有点像缓存技术
fangpengyu 2009-05-23
  • 打赏
  • 举报
回复
DriverManager是直接和数据库地层连接
DataSource是用数据库连接池进行封装好获得连接的,访问量大的项目最好用连接池
william3033 2009-05-11
  • 打赏
  • 举报
回复
同学习~~~~
顺便接点分。
按理说配置DataSource,由容器来获取结合连接池的应用比JDBC直接操作应该效率比较高。
不善^ 2009-05-09
  • 打赏
  • 举报
回复
写成javabean也不错啊
happydaisy1985 2009-05-09
  • 打赏
  • 举报
回复
来学习的,呵呵,顺便帮lz顶顶!!
wfeng007 2009-05-07
  • 打赏
  • 举报
回复
datasource内部封装了 DriverManager的使用。。。
DataSource主要是为了方便配置使用。。。 作为OO概念上也需要有这个类和对象来表示数据的来源。。。



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



luffyke 2009-04-30
  • 打赏
  • 举报
回复
datasource是与连接池获取连接,而datamanager是获取与数据库的连接!datamanager类的主要作用是管理注册到datamanager中的JDBC驱动程序,并根据需要使用JDBC驱动程序建立与数据服务器的网络连接。但是建立与数据库的连接是一项较耗资源的工作,频繁的进行数据库连接建立操作会产生较大的系统开销,为了解决上述问题,可以采用数据库连接池技术。
jinxfei 2009-04-30
  • 打赏
  • 举报
回复
粗浅理解:

如题 同样是获取连接,这两种方法有什么区别?
本质上没啥不同吧。
一个是你自己控制了jdbc最底层的初始化并拿到连接(DriverManiger)
一个是由容器封装成数据源(底层也是第一种方式),然后获取连接。
使用DataSource的好处是可以在外边配置,不用自己写配置文件了。


还有大并发的事情是web服务器做的还是像hibernate中的c3p0这样的东西做的?
大并发,呵呵,好大一个课题。
hibernate是持久层,可以认为跟大并发没啥关系(很多观点认为,hibernate的性能相当成问题),
c3p0是连接池(也就是放好多connection在里面随时供调用),
可以独立使用的,做大并发访问,数据库连接池是必不可少的,
web服务器也很关键,要有优秀的线程调度能力。

如果真的是很大的并发两,从网络、主机、数据库、应用服务器可能都要有所规划才行。
网络要大带宽,
主机集群,
数据库优化,
应用服务器负载均衡。

总之很复杂。

67,518

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧