Java数据库接口JDBC基础教程之驱动配置

DriverManager 类是 JDBC 的管理层,作用于用户和驱动程式之间。他跟踪可用的驱动程式,并在数据库和相应驱动程式之间建立连接。另外,DriverManager 类也处理诸如驱动程式登录时间限制及登录和跟踪消息的显示等事务。

  对于简单的应用程式,一般程式员需要在此类中直接使用的唯一方法是 DriverManager.getConnection。正如名称所示,该方法将建立和数据库的连接。JDBC 允许用户调用 Dr
用UC每月免费发短信 新浪点点通天气
为什么美国人打错靶? 1拍网caiso腕表5.8折


iverManager 的方法 getDriver、getDrivers 和 registerDriver 及 Driver 的方法 connect。但多数情况下,让 DriverManager 类管理建立连接的细节为上策。

  1、跟踪可用驱动程式

  DriverManager 类包含一列 Driver 类,他们已通过调用方法 DriverManager.registerDriver 对自己进行了注册。任何 Driver 类都必须包含有一个静态部分。他创建该类的实例,然后在加载该实例时 DriverManager 类进行注册。这样,用户正常情况下将不会直接调用 DriverManager.registerDriver;而是在加载驱动程式时由驱动程式自动调用。加载 Driver 类,然后自动在 DriverManager 中注册的方式有两种:

  通过调用方法 Class.forName。这将显式地加载驱动程式类。由于这和外部配置无关,因此推荐使用这种加载驱动程式的方法。以下代码加载类 acme.db.Driver:

  Class.forName("acme.db.Driver");

  假如将 acme.db.Driver 编写为加载时创建实例,并调用以该实例为参数的 DriverManager.registerDriver(本该如此),则他在 DriverManager 的驱动程式列表中,并可用于创建连接。

  通过将驱动程式添加到 java.lang.System 的属性 jdbc.drivers 中。这是个由 DriverManager 类加载的驱动程式类名的列表,由冒号分隔:初始化 DriverManager 类时,他搜索系统属性 jdbc.drivers,假如用户已输入了一个或多个驱动程式,则 DriverManager 类将试图加载他们。以下代码说明程式员如何在 ~/.hotjava/properties 中输入三个驱动程式类(启动时,HotJava 将把他加载到系统属性列表中):

  jdbc.drivers=foo.bah.Driver:wombat.sql.Driver:bad.test.ourDriver;

  对 DriverManager 方法的第一次调用将自动加载这些驱动程式类。

  注意:加载驱动程式的第二种方法需要持久的预设环境。假如对这一点不能确保,则调用方法 Class.forName 显式地加载每个驱动程式就显得更为安全。这也是引入特定驱动程式的方法,因为一旦 DriverManager 类被初始化,他将不再检查 jdbc.drivers 属性列表。

  在以上两种情况中,新加载的 Driver 类都要通过调用 DriverManager.registerDriver 类进行自我注册。如上所述,加载类时将自动执行这一过程。

  由于安全面的原因,JDBC 管理层将跟踪哪个类加载器提供哪个驱动程式。这样,当 DriverManager 类打开连接时,他仅使用本地文档系统或和发出连接请求的代码相同的类加载器提供的驱动程式。

  2、建立连接

  加载 Driver 类并在 DriverManager 类中注册后,他们即可用来和数据库建立连接。当调用 DriverManager.getConnection 方法发出连接请求时,DriverManager 将检查每个驱动程式,查看他是否能够建立连接。

  有时可能有多个 JDBC 驱动程式能够和给定的 URL 连接。例如,和给定远程数据库连接时,能够使用 JDBC-ODBC 桥驱动程式、JDBC 到通用网络协议驱动程式或数据库厂商提供的驱动程式。在这种情况下,测试驱动程式的顺序至关重要,因为 DriverManager 将使用他所找到的第一个能够成功连接到给定 URL 的驱动程式。

  首先 DriverManager 试图按注册的顺序使用每个驱动程式(jdbc.drivers 中列出的驱动程式总是先注册)。他将跳过代码不可信任的驱动程式,除非加载他们的源和试图打开连接的代码的源相同。

  他通过轮流在每个驱动程式上调用方法 Driver.connect,并向他们传递用户开始传递给方法 DriverManager.getConnection 的 URL 来对驱动程式进行测试,然后连接第一个认出该 URL 的驱动程式。

  这种方法初看起来效率不高,但由于不可能同时加载数十个驱动程式,因此每次连接实际只需几个过程调用和字符串比较。

  以下代码是通常情况下用驱动程式(例如 JDBC-ODBC 桥驱动程式)建立连接所需任何步骤的示例:

  Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); //加载驱动程式

  String url = "jdbc:odbc:fred";

  DriverManager.getConnection(url, "userID", "passwd"); 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值