DriverManager 驱动管理器类简介 JDBC简介(三)

时间:2021-09-02 00:52:40
驱动程序管理器是负责管理驱动程序的,驱动注册以后,会保存在DriverManager中的已注册列表中
后续的处理就可以对这个列表进行操作
DriverManager 驱动管理器类简介   JDBC简介(三)
简言之,驱动管理器,就是字面含义,主要负责就是管理 驱动

概述

DriverManager 驱动管理器类简介   JDBC简介(三)
提供管理一组 JDBC 驱动程序的基本服务。
 
驱动注册中提到过,拥有初始化方法  loadInitialDrivers();
主要两件事情:
读取jdbc.drivers系统属性加载以及查询符合4.0规范的驱动程序加载。
DriverManager 类会尝试加载在 "jdbc.drivers" 系统属性中引用的驱动程序类。
这允许用户定制由他们的应用程序使用的 JDBC Driver。例如,可以在properties 文件中,指定:
jdbc.drivers=foo.bah.Driver:wombat.sql.Driver:bad.taste.ourDriver
JDBC 4.0 Drivers 必须包括 META-INF/services/java.sql.Driver 文件。此文件包含 java.sql.Driver 的 JDBC 驱动程序实现的名称。
例如,要加载 my.sql.Driver 类,META-INF/services/java.sql.Driver 文件需要包含下面的条目:
my.sql.Driver
应用程序不再需要使用 Class.forName() 显式地加载 JDBC 驱动程序。
当前使用 Class.forName() 加载 JDBC 驱动程序的现有程序将在不作修改的情况下继续工作。
 
在调用 getConnection 方法时,DriverManager 会试着从初始化时加载的那些驱动程序以及使用与当前 applet 或应用程序相同的类加载器显式加载的那些驱动程序中查找合适的驱动程序。

创建连接

DriverManager负责驱动程序管理,数据库驱动则是为了应用程序服务的,所以DriverManager的重要任务就是提供连接的获取。
通过DriverManager获得连接,对应用程序开发者是非常重要的一件事情。
通过getConnection方法获得Connection对象
DriverManager 驱动管理器类简介   JDBC简介(三)
可以看得出来,三个公共的getConnection方法并没有什么太多逻辑,只是参数形式的适配,方法内部调用的都是私有的getConnection方法
在方法内部主要就是循环遍历所有的已注册的驱动程序,尝试建立连接
如果建立连接成功,就返回这个连接
DriverManager 驱动管理器类简介   JDBC简介(三)

驱动程序查找

DriverManager管理驱动程序,不仅仅提供了借助于驱动程序创建连接的能力
还能够返回给定的Driver或者Driver 列表
    public static Driver getDriver(String url) throws SQLException  
    public static java.util.Enumeration<Driver> getDrivers()  
getDriver
给定一个URL,查找能理解给定 URL 的驱动程序。DriverManager 试图从已注册的 JDBC 驱动程序集中选择一个适当的驱动程序。 
如果不存在throw new SQLException("No suitable driver", "08001");
getDrivers
getDrivers 返回的是一个枚举  java.util.Enumeration<Driver>

注册与卸载

如同仓库,有进货和出货,DriverManager作为驱动程序管理器,需要提供注册和卸载的能力。
相关的方法为registerDriver和deregisterDriver
注册和卸载应用程序开发者不需要过多关注 
注册
有两个版本的注册方法,核心是一样的,都是用于将驱动程序记录在案,保存在容器中
新加载的驱动程序类应该调用 registerDriver 方法让 DriverManager 知道自己
DriverManager 驱动管理器类简介   JDBC简介(三)
两个方法的区别在于new DriverInfo(driver, da)的第二个参数,类型为DriverAction
当驱动程序想要被驱动管理器通知时必须实现的接口。
JDBC驱动程序的静态初始化块中使用双参数版本的注册方法时,当驱动程序被卸载时,会被调用。
DriverManager 驱动管理器类简介   JDBC简介(三)
 
卸载
public static void deregisterDriver(Driver driver)
                             throws SQLException
从DriverManager的注册驱动程序列表中移除指定的驱动程序。
如果参数为NULL,什么都不做
如果存在安全管理器且它的checkPermission拒绝权限,则会抛出SecurityException。
如果在注册的驱动程序列表中没有找到指定的驱动程序,什么都不做;如果找到驱动程序,它将从注册驱动程序列表中删除。
如果在注册JDBC驱动程序时指定了DriverAction ,那么在从注册驱动程序列表中删除驱动程序之前,将调用他的deregister方法。

连接超时设置

驱动程序试图连接到某一数据库时的最大等待时长loginTimeout,以秒为单位,可以对这个数值进行设置和读取。
 
public static void setLoginTimeout(int seconds)
public static int getLoginTimeout()

日志

DriverManager内部有一个PrintWriter
这个PrintWriter 是DriverManager 和所有驱动程序使用的日志/追踪 对象
提供了set和get方法
public static void setLogWriter(java.io.PrintWriter out)
public static java.io.PrintWriter getLogWriter() 
DriverManager 驱动管理器类简介   JDBC简介(三)
 
除了能够对日志、追踪对象进行设置和获取外
还有日志记录方法,借助于logWriter进行写入,然后刷新
public  static void println(String message)
DriverManager 驱动管理器类简介   JDBC简介(三) 

总结

DriverManager用于管理驱动程序以及驱动程序的注册相关,应用程序开发者主要关注于借助于驱动程序管理器创建指定的连接
也就是说重点关注于getConnection方法,所有后续的数据库操作都要基于这个连接进行,其他的一些方法了解下即可,开发环境中是基本不会直接接触的

DriverManager 驱动管理器类简介 JDBC简介(三)的更多相关文章

  1. Data Source与数据库连接池简介 JDBC简介(八)

    DataSource是作为DriverManager的替代品而推出的,DataSource 对象是获取连接的首选方法. 起源 为何放弃DriverManager DriverManager负责管理驱动 ...

  2. JDBC 异常简介 jDBC简介(六)

    SQL 异常简介 对于数据库的操作访问,必然也很可能抛出异常. JDBC中定义了SQLException,用于描述数据库相关操作中可能出现的异常情况. java.sql.SQLException    ...

  3. &lbrack;连载&rsqb;《C&num;通讯(串口和网络)框架的设计与实现》-4&period;设备驱动管理器的设计

    目       录 第四章           设备驱动管理器的设计... 2 4.1           接口定义... 2 4.2           设备容器... 7 4.3          ...

  4. X509证书信任管理器类的详解

    在JSSE中,证书信任管理器类就是实现了接口X509TrustManager的类.我们可以自己实现该接口,让它信任我们指定的证书. 接口X509TrustManager有下述三个公有的方法需要我们实现 ...

  5. VS2013中Nuget程序包管理器控制台使用入门(三)-项目实战(原创)

    VS2013中Nuget程序包管理器控制台使用入门(三)-项目实战 1.给指定项目安装Newtonsoft.Json ,Version 4.5.11 PM> Install-Package Ne ...

  6. Django 自定义模型管理器类2个应用场景

    class BookManager(models.Manager): # 改变查询集的结果集 def all(self): books = super().all() # QuerySet books ...

  7. 好用的Quartz管理器类

    转发的代码,原理就不提了 下面直接上代码: QuartzManager.java 动态添加.修改和删除定时任务管理类 import org.quartz.CronScheduleBuilder; im ...

  8. JDBC简介及JDBC编写步骤及常见API

    JDBC : Java Database Connectivity,Java数据库连接.SUN公司为了简化.统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC. JDBC就像一座桥 ...

  9. jdbc连接数据库三种方式

    ---恢复内容开始--- 第一种: public class Demo1 { //连接数据库的URL private String url = "jdbc:mysql://localhost ...

随机推荐

  1. ios 基于CAEmitterLayer的雪花,烟花,火焰,爱心等效果demo

    demo功能:基于CAEmitterLayer的雪花,烟花,火焰,爱心等效果. demo说明:基于Core Animation的粒子发射系统,粒子用CAEmitterCell来初始化. 粒子画在背景层 ...

  2. CVE-2014-4113:飓风熊猫(HURRICANE PANDA)Win64bit提起权0day破绽

    飓风熊猫被觉得是原产于中国.主要针对基础设施公司的先进攻击者.我们知道它们除了拥有0day漏洞外.还有其它的三种本地特权提升漏洞.我们知道飓风熊猫使用的是"ChinaChopper&quot ...

  3. 二、 添加控制器Controller(ASP&period;NET MVC5 系列)

    MVC是Model-View-Controller的简写.MVC是一种开发良好架构,可测试,易维护应用程序的设计模式.据于MVC的应用程序应该包含: Models: 是呈现应用程序数据和使用验证逻辑给 ...

  4. 201521123112《Java程序设计》第6周学习总结

    1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 注1:关键词与内容不求多,但概念之间的联系要清晰,内容覆盖 ...

  5. Macaca拓展自己控件的方法

    https://github.com/macacajs/wd.py/blob/3bc4334bcb68733cb230b59d6164110053fd1c16/tests/macaca/test_ut ...

  6. 利用百度地图api实现定位

    使用百度地图api前需要先获取一个百度地图开放平台的访问应用AK, 获取百度地图开放平台访问应用AK方式:注册百度账号-->申请百度开发者-->获取密匙-->使用相关功能. 注册账号 ...

  7. 彻底理解js中的&amp&semi;&amp&semi;和&vert;&vert;

    阅读代码时对一行代码很困惑 step > max_step && (step = min_step); 查阅资料后发现它等价于 if (step > max_step) { ...

  8. 无备份时用dbms&lowbar;repair恢复坏块的方法

    份的情况下可以直接使用备份来恢复. 对于通过备份恢复,Oracel为我们提供了很多种方式,冷备,基于用户管理方式,RMAN方式等等. 对于这几种方式我们需要实现基于数据库以及文件级别的恢复.RMAN同 ...

  9. Mean shift

    转载:http://blog.csdn.net/google19890102/article/details/51030884 然后引入opencv中的pyrMeanShiftFiltering函数: ...

  10. C&num;重写ToString

    C# 中的每个类或结构都可隐式继承 <xref:System.Object> 类. 因此,C# 中的每个对象都会获取 <xref:System.Object.ToString%2A& ...