WEB应用与开发_09JDBC与数据库(原理、JDBC与数据库的连接)_第1页
WEB应用与开发_09JDBC与数据库(原理、JDBC与数据库的连接)_第2页
WEB应用与开发_09JDBC与数据库(原理、JDBC与数据库的连接)_第3页
WEB应用与开发_09JDBC与数据库(原理、JDBC与数据库的连接)_第4页
WEB应用与开发_09JDBC与数据库(原理、JDBC与数据库的连接)_第5页
已阅读5页,还剩65页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、课题课题JDBC与数据库(原理、与数据库(原理、JDBC与数据库与数据库的连接)的连接)目的要求目的要求 掌握掌握JDBC的基本概念及的基本概念及JDBC类的的基类的的基本方法本方法 教学重点教学重点 JDBC的概念、的概念、JDBC驱动程序的类型及驱动程序的类型及与数据库的连接与数据库的连接教学难点教学难点 JDBC与不同数据库的连接与处理与不同数据库的连接与处理教学课时教学课时 4(含(含2课时上机)课时上机)教学方法教学方法 讲解、示例与启发式教学相结合讲解、示例与启发式教学相结合教学内容和步骤教学内容和步骤9.1 JDBC9.1 JDBC与数据库与数据库9.1.1 9.1.1 什么是什

2、么是 JDBCTMJDBCTM? JDBCTM JDBCTM 是一种用于执行是一种用于执行 SQL SQL 语句的语句的 JavaTM APIJavaTM API(有意思的是,(有意思的是,JDBC JDBC 本身是个商标名而不是一个本身是个商标名而不是一个缩写字;然而,缩写字;然而,JDBCJDBC常被认为是代表常被认为是代表 “ “Java Java 数据数据库连接库连接 (Java Database Connectivity)”(Java Database Connectivity)”)。它)。它由一组用由一组用 Java Java 编程语言编写的类和接口组成。编程语言编写的类和接口组成

3、。JDBC JDBC 为工具为工具/ /数据库开发人员提供了一个标准的数据库开发人员提供了一个标准的 APIAPI,使他们能够用纯,使他们能够用纯Java API Java API 来编写数据库应用来编写数据库应用程序。程序。有了有了 JDBC,向各种关系数据库发送,向各种关系数据库发送 SQL 语句就是一件很语句就是一件很容易的事。换言之,有了容易的事。换言之,有了JDBC API,就不必为访问,就不必为访问 Sybase 数据库专门写一个程序,为访问数据库专门写一个程序,为访问 Oracle 数据库又数据库又专门写一个程序,为访问专门写一个程序,为访问Informix 数据库又写另一个程数

4、据库又写另一个程序,等等。您只需用序,等等。您只需用 JDBC API 写一个程序就够了,它可写一个程序就够了,它可向相应数据库发送向相应数据库发送 SQL 语句。而且,使用语句。而且,使用 Java 编程语言编程语言编写的应用程序,就无须去忧虑要为不同的平台编写不编写的应用程序,就无须去忧虑要为不同的平台编写不同的应用程序。将同的应用程序。将 Java 和和 JDBC 结合起来将使程序员只结合起来将使程序员只须写一遍程序就可让它在任何平台上运行。须写一遍程序就可让它在任何平台上运行。Java 具有坚固、安全、易于使用、易于理解和可从网络上自具有坚固、安全、易于使用、易于理解和可从网络上自动下

5、载等特性,是编写数据库应用程序的杰出语言。所需要动下载等特性,是编写数据库应用程序的杰出语言。所需要的只是的只是 Java 应用程序与各种不同数据库之间进行对话的方法。应用程序与各种不同数据库之间进行对话的方法。而而 JDBC 正是作为此种用途的机制。正是作为此种用途的机制。JDBC 扩展了扩展了 Java 的功能。例如,用的功能。例如,用 Java 和和 JDBC API 可以发布含有可以发布含有 applet的网页,而该的网页,而该 applet 使用的信息可能来自远程数据库。企业使用的信息可能来自远程数据库。企业也可以用也可以用 JDBC 通过通过Intranet 将所有职员连到一将所有

6、职员连到一个或多个内部数据库中(即使这些职员所用的个或多个内部数据库中(即使这些职员所用的计算机有计算机有 Windows、 Macintosh 和和 UNIX 等各种等各种不同的操作系统)。随着越来越多的程序员开不同的操作系统)。随着越来越多的程序员开始使用始使用 Java 编程语言,对从编程语言,对从 Java中便捷地访问中便捷地访问数据库的要求也在日益增加。数据库的要求也在日益增加。MIS 管理员们都喜欢管理员们都喜欢 Java 和和 JDBC 的结合,因为它使信息的结合,因为它使信息传播变得容易和经济。企业可继续使用它们安装好的数据传播变得容易和经济。企业可继续使用它们安装好的数据库,

7、并能便捷地存取信息,即使这些信息是储存在不同数库,并能便捷地存取信息,即使这些信息是储存在不同数据库管理系统上。新程序的开发期很短。安装和版本控制据库管理系统上。新程序的开发期很短。安装和版本控制将大为简化。程序员可只编写一遍应用程序或只更新一次,将大为简化。程序员可只编写一遍应用程序或只更新一次,然后将它放到服务器上,随后任何人就都可得到最新版本然后将它放到服务器上,随后任何人就都可得到最新版本的应用程序。对于商务上的销售信息服务,的应用程序。对于商务上的销售信息服务, Java 和和 JDBC 可为外部客户提供获取信息更新的更好方法。可为外部客户提供获取信息更新的更好方法。9.1.2 JD

8、BC 的用途是什么?的用途是什么?简单地说,简单地说,JDBC 可做三件事:可做三件事: 与数据库建立连接,与数据库建立连接, 发送发送 SQL 语句,语句, 处理结果。处理结果。下列代码段给出了以上三步的基本示例:下列代码段给出了以上三步的基本示例:Connection con = DriverManager.getConnection (jdbc:odbc:wombat, login, password);Statement stmt = con.createStatement();ResultSet rs = stmt.executeQuery(SELECT a, b, c FROM T

9、able1);while (rs.next()System.out.println(rs.getString(a) + + rs.getString(b) + + rs.getString(c);9.1.3 JDBC API 简介简介JDBC 是个是个“低级低级”接口,也就是说,它用于直接口,也就是说,它用于直接调用接调用 SQL 命令。在这方面它的功能极佳,并比其它命令。在这方面它的功能极佳,并比其它的数据库连接的数据库连接 API 易于使用,但它同时也被设计为一种易于使用,但它同时也被设计为一种基础接口,在它之上可以建立高级接口和工具。基础接口,在它之上可以建立高级接口和工具。高级接口是高

10、级接口是“对用户友好的对用户友好的”接口,它使用的是接口,它使用的是一种更易理解和更为方便的一种更易理解和更为方便的 API,这种,这种 API 在幕后被转在幕后被转换为诸如换为诸如 JDBC 这样的低级接口。在编写本文时,正在这样的低级接口。在编写本文时,正在开发两种基于开发两种基于 JDBC 的高级的高级 API:一种用于一种用于 Java 的嵌入式的嵌入式 SQL。至少已经有一个提供者计划。至少已经有一个提供者计划编写它。编写它。DBMS 实现实现SQL:一种专门设计来与数据库联合使:一种专门设计来与数据库联合使用的语言。用的语言。JDBC 要求要求 SQL 语句必须作为语句必须作为 S

11、tring 传给传给 Java 方方法。相反,嵌入式法。相反,嵌入式 SQL预处理器允许程序员将预处理器允许程序员将 SQL 语句直接语句直接与与Java 混在一起使用。例如,可在混在一起使用。例如,可在 SQL 语句中使用语句中使用 Java 变变量,用以接受或提供量,用以接受或提供SQL 值。然后,嵌入式值。然后,嵌入式 SQL 预处理器将预处理器将通过通过 JDBC 调用把这种调用把这种 Java/SQL 的混合物转换为的混合物转换为Java。关系。关系数据库表到数据库表到 Java 类的直接映射。类的直接映射。JavaSoft 和其它提供者都声和其它提供者都声称要实现该称要实现该API

12、。在这种。在这种“对象对象/关系关系”映射中,表中的每行映射中,表中的每行对应于类的一个实例,而每列的值对应于该实例的一个属对应于类的一个实例,而每列的值对应于该实例的一个属性。于是,程序员可直接对性。于是,程序员可直接对 Java 对象进行操作;存取数据对象进行操作;存取数据所需的所需的 SQL 调用将在调用将在“掩盖下掩盖下”自动生成。此外还可提供自动生成。此外还可提供更复杂的映射,例如将多个表中的行结合进一个更复杂的映射,例如将多个表中的行结合进一个 Java 类中。类中。随着人们对随着人们对 JDBC 的兴趣日益增涨,越来越多的开发的兴趣日益增涨,越来越多的开发人员一直在使用基于人员一

13、直在使用基于 JDBC 的工具,以使程序的编写更的工具,以使程序的编写更加容易。程序员也一直在编写力图使最终用户对数据库加容易。程序员也一直在编写力图使最终用户对数据库的访问变得更为简单的应用程序。例如,应用程序可提的访问变得更为简单的应用程序。例如,应用程序可提供一个选择数据库任务的菜单。任务被选定后,应用程供一个选择数据库任务的菜单。任务被选定后,应用程序将给出提示及空白供填写执行选定任务所需的信息。序将给出提示及空白供填写执行选定任务所需的信息。所需信息输入后,应用程序将自动调用所需的所需信息输入后,应用程序将自动调用所需的SQL 命令。命令。在这样一种程序的协助下,即使用户根本不懂在这

14、样一种程序的协助下,即使用户根本不懂 SQL 的语的语法,也可以执行数据库任务。法,也可以执行数据库任务。 JDBC 与与 ODBC 和其它和其它 API 的比较的比较目前,目前,Microsoft 的的 ODBC(开放式数据库连接)(开放式数据库连接)API 可可能是使用最广的、用于访问关系数据库的编程接口。它能在几能是使用最广的、用于访问关系数据库的编程接口。它能在几乎所有平台上连接几乎所有的数据库。为什么乎所有平台上连接几乎所有的数据库。为什么Java 不使用不使用 ODBC?对这个问题的回答是:对这个问题的回答是:Java 可以使用可以使用 ODBC,但最好是,但最好是在在 JDBC

15、的帮助下以的帮助下以JDBC-ODBC 桥的形式使用,这一点我们稍桥的形式使用,这一点我们稍后再说。现在的问题已变成:后再说。现在的问题已变成:“为什么需要为什么需要 JDBC”? 回答如下:回答如下:ODBC 不适合直接在不适合直接在 Java 中使用,因为它使用中使用,因为它使用 C 语言接口。从语言接口。从 Java 调用本地调用本地 C 代码在安全性、实现、坚固性和程序的自动移代码在安全性、实现、坚固性和程序的自动移植性方面都有许多缺点。植性方面都有许多缺点。从从 ODBC API 到到 Java API 的字面翻译是不可取的。例如,的字面翻译是不可取的。例如,Java 没有指针,而没

16、有指针,而 ODBC 却对指针用得很广泛(包括却对指针用得很广泛(包括很容易出错的指针很容易出错的指针 void *)。您可以将)。您可以将 JDBC 想象成想象成被转换为面向对象接口的被转换为面向对象接口的 ODBC,而面向对象的接口对,而面向对象的接口对 Java 程序员来说较易于接收。程序员来说较易于接收。ODBC 很难学。它把简单很难学。它把简单和高级功能混在一起,而且即使对于简单的查询,其和高级功能混在一起,而且即使对于简单的查询,其选项也极为复杂。相反,选项也极为复杂。相反,JDBC 尽量保证简单功能的简尽量保证简单功能的简便性,而同时在必要时允许使用高级功能。启用便性,而同时在必

17、要时允许使用高级功能。启用“纯纯 Java ”机制需要象机制需要象 JDBC 这样的这样的 Java API。如果使用。如果使用 ODBC,就必须手动地将,就必须手动地将 ODBC 驱动程序管理器和驱动驱动程序管理器和驱动程序安装在每台客户机上。如果完全用程序安装在每台客户机上。如果完全用 Java 编写编写 JDBC 驱动程序则驱动程序则 JDBC 代码在所有代码在所有 Java 平台上(从网络计算平台上(从网络计算机到大型机)都可以自动安装、移植并保证安全性。机到大型机)都可以自动安装、移植并保证安全性。总之,总之,JDBC API 对于基本的对于基本的 SQL 抽象和概念是一种自抽象和概

18、念是一种自然的然的 Java 接口。它建立在接口。它建立在 ODBC 上而不是从零开始。上而不是从零开始。因此,熟悉因此,熟悉ODBC 的程序员将发现的程序员将发现 JDBC 很容易使用。很容易使用。JDBC 保留了保留了 ODBC 的基本设计特征;事实上,两种接的基本设计特征;事实上,两种接口都基于口都基于 X/Open SQL CLI(调用级接口)。它们之间(调用级接口)。它们之间最大的区别在于:最大的区别在于:JDBC 以以 Java 风格与优点为基础并风格与优点为基础并进行优化,因此更加易于使用进行优化,因此更加易于使用。最近,最近,Microsoft 又引进了又引进了 ODBC 之外

19、的新之外的新 API: RDO、 ADO 和和 OLE DB。这些设计在许多方面与。这些设计在许多方面与 JDBC 是相同的,是相同的,即它们都是面向对象的数据库接口且基于可在即它们都是面向对象的数据库接口且基于可在ODBC 上上实现的类。但在这些接口中,我们未看见有特别的功能实现的类。但在这些接口中,我们未看见有特别的功能使我们要转而选择它们来替代使我们要转而选择它们来替代 ODBC,尤其是在,尤其是在 ODBC 驱驱动程序已建立起较为完善的市场的情况下。它们最多也动程序已建立起较为完善的市场的情况下。它们最多也就是在就是在 ODBC 上加了一种装饰而已。这并不是说上加了一种装饰而已。这并不

20、是说 JDBC 不不需要从其最初的版本再发展了;然而,我们觉得大部份需要从其最初的版本再发展了;然而,我们觉得大部份的新功能应归入诸如前一节中所述的对象的新功能应归入诸如前一节中所述的对象/关系映射和嵌关系映射和嵌入式入式 SQL 这样的高级这样的高级 API。 两层模型和三层模型两层模型和三层模型JDBC API 既支持数据库访问的两层模型,同时既支持数据库访问的两层模型,同时也支持三层模型。也支持三层模型。在两层模型中,在两层模型中,Java applet 或应用程序将直接与数或应用程序将直接与数据库进行对话。这将需要一个据库进行对话。这将需要一个 JDBC 驱动程序来与所驱动程序来与所访

21、问的特定数据库管理系统进行通讯。用户的访问的特定数据库管理系统进行通讯。用户的 SQL 语语句被送往数据库中,而其结果将被送回给用户。数据句被送往数据库中,而其结果将被送回给用户。数据库可以位于另一台计算机上,用户通过网络连接到上库可以位于另一台计算机上,用户通过网络连接到上面。这就叫做客户机面。这就叫做客户机/服务器配置,其中用户的计算服务器配置,其中用户的计算机为客户机,提供数据库的计算机为服务器。网络可机为客户机,提供数据库的计算机为服务器。网络可以是以是 Intranet(它可将公司职员连接起来),也可以(它可将公司职员连接起来),也可以是是 Internet。在三层模型中,命令先是被

22、发送到服务的在三层模型中,命令先是被发送到服务的“中间层中间层”,然,然后由它将后由它将 SQL 语句发送给数据库。数据库对语句发送给数据库。数据库对 SQL 语句进语句进行处理并将结果送回到中间层,中间层再将结果送回给用行处理并将结果送回到中间层,中间层再将结果送回给用户。户。MIS 主管们都发现三层模型很吸引人,因为可用中间主管们都发现三层模型很吸引人,因为可用中间层来控制对公司数据的访问和可作的的更新的种类。中间层来控制对公司数据的访问和可作的的更新的种类。中间层的另一个好处是,用户可以利用易于使用的高级层的另一个好处是,用户可以利用易于使用的高级API,而中间层将把它转换为相应的低级调

23、用。最后,许多情况而中间层将把它转换为相应的低级调用。最后,许多情况下三层结构可提供一些性能上的好处。下三层结构可提供一些性能上的好处。到目前为止,中间层通常都用到目前为止,中间层通常都用 C 或或 C+ 这类语言来这类语言来编写,这些语言执行速度较快。然而,随着最优化编编写,这些语言执行速度较快。然而,随着最优化编译器(它把译器(它把 Java字节代码转换为高效的特定于机器的字节代码转换为高效的特定于机器的代码)的引入,用代码)的引入,用 Java 来实现中间层将变得越来越实来实现中间层将变得越来越实际。这将是一个很大的进步,它使人们可以充分利用际。这将是一个很大的进步,它使人们可以充分利用

24、 Java 的诸多优点(如坚固、多线程和安全等特征)。的诸多优点(如坚固、多线程和安全等特征)。JDBC对于从对于从 Java 的中间层来访问数据库非常重要。的中间层来访问数据库非常重要。 SQL 的一致性的一致性结构化查询语言结构化查询语言 (SQL) 是访问关系数据库的标准语言。是访问关系数据库的标准语言。困难之处在于:虽然大多数的困难之处在于:虽然大多数的 DBMS (数据库管理系统)对(数据库管理系统)对其基本功能都使用了标准形式的其基本功能都使用了标准形式的 SQL,但它们却不符合最近,但它们却不符合最近为更高级的功能定义的标准为更高级的功能定义的标准SQL 语法或语义。例如,并非所

25、语法或语义。例如,并非所有的数据库都支持储存程序或外部连接,那些支持这一功能有的数据库都支持储存程序或外部连接,那些支持这一功能的数据库又相互不一致。人们希望的数据库又相互不一致。人们希望 SQL 中真正标准的那部份中真正标准的那部份能够进行扩展以包括越来越多的功能。但同时能够进行扩展以包括越来越多的功能。但同时 JDBC API 又必又必须支持现有的须支持现有的 SQL。JDBC API 解决这个问题的一种方法是允许将任何查询解决这个问题的一种方法是允许将任何查询字符串一直传到所涉及的字符串一直传到所涉及的DBMS 驱动程序上。这意味驱动程序上。这意味着应用程序可以使用任意多的着应用程序可以

26、使用任意多的 SQL 功能,但它必须冒功能,但它必须冒这样的风险:有可能在某些这样的风险:有可能在某些 DBMS 上出错。事实上,上出错。事实上,应用程序查询甚至不一定要是应用程序查询甚至不一定要是SQL,或者说它可以是,或者说它可以是个为特定的个为特定的 DBMS 设计的设计的 SQL 的专用派生物(例如,的专用派生物(例如,文档或图象查)。文档或图象查)。JDBC 处理处理 SQL 一致性问题的第二种方法是提供一致性问题的第二种方法是提供 ODBC 风格的转义子句。风格的转义子句。转义语法为几个常见的转义语法为几个常见的 SQL 分歧提供了一分歧提供了一种标准的种标准的 JDBC 语法。例

27、如,对日期文字和已储存语法。例如,对日期文字和已储存过程的调用都有转义语法。过程的调用都有转义语法。对于复杂的应用程序,对于复杂的应用程序,JDBC 用第三种方法用第三种方法来处理来处理 SQL 的一致性问题。它利用的一致性问题。它利用DatabaseMetaData 接口来提供关于接口来提供关于 DBMS 的描述的描述性信息,从而使应用程序能适应每个性信息,从而使应用程序能适应每个 DBMS 的要的要求和功能。求和功能。由于由于 JDBC API 将用作开发高级数据库访问工具和将用作开发高级数据库访问工具和 API 的基础的基础 API,因此它还必须注意其所有上层建,因此它还必须注意其所有上

28、层建筑的一致性。筑的一致性。“符合符合JDBC 标准标准TM 代表用户可依代表用户可依赖的赖的 JDBC 功能的标准级别。要使用这一说明,驱功能的标准级别。要使用这一说明,驱动程序至少必须支持动程序至少必须支持 ANSI SQL-2 EntryLevel(ANSI SQL-2 代表美国国家标准局代表美国国家标准局 1992 年所采用的标准。年所采用的标准。Entry Level 代表代表SQL 功能的特定清单)。驱动程序功能的特定清单)。驱动程序开发人员可用开发人员可用 JDBC API 所带的测试工具包来确定所带的测试工具包来确定他们的驱动程序是否符合这些标准。他们的驱动程序是否符合这些标准

29、。“符合符合 JDBC 标准标准TM” 表示提供者的表示提供者的 JDBC 实现已经通过了实现已经通过了 JavaSoft 提供的一致性测试。这些一致性测试将检查提供的一致性测试。这些一致性测试将检查 JDBCAPI 中定义的所有类和方法是否都存在,并尽可能地检查程序是中定义的所有类和方法是否都存在,并尽可能地检查程序是否具有否具有 SQL Entry Level 功能。当然,这些测试并不完全,而功能。当然,这些测试并不完全,而且且 JavaSoft 目前也无意对各提供者的实现进行标级。但这种目前也无意对各提供者的实现进行标级。但这种一致性定义的确可对一致性定义的确可对JDBC 实现提供一定的

30、可信度。随着越来实现提供一定的可信度。随着越来越多的数据库提供者、连接提供者、越多的数据库提供者、连接提供者、Internet 提供者和应用程提供者和应用程序编程员对序编程员对 JDBC API 的接受,的接受,JDBC 也正迅速成为也正迅速成为 Java数据库数据库访问的标准。访问的标准。9.1.4 JDBC 产品产品在编写本文时,有几个基于在编写本文时,有几个基于 JDBC 的产品已开的产品已开发完毕或正在开发中。当然,本节中的信息将很快发完毕或正在开发中。当然,本节中的信息将很快成为过时信息。因此,有关最新的信息,请查阅成为过时信息。因此,有关最新的信息,请查阅 JDBC 的网站,可通过

31、从以下的网站,可通过从以下 URL 开始浏览找到:开始浏览找到:http:/ 提供三种提供三种 JDBC 产品组件,它们是产品组件,它们是 Java 开发工具包开发工具包 (JDK) 的组成部份:的组成部份: JDBC 驱动程序管理器驱动程序管理器JDBC 驱动程序管理器是驱动程序管理器是 JDBC 体系结构的支体系结构的支柱。它实际上很小,也很简单;其主要作用是柱。它实际上很小,也很简单;其主要作用是把把 Java 应用程序连接到正确的应用程序连接到正确的JDBC 驱动程序上,驱动程序上,然后即退出。然后即退出。 JDBC 驱动程序测试工具包驱动程序测试工具包JDBC 驱动程序测试工具包为使

32、驱动程序测试工具包为使 JDBC 驱动程序运行您的驱动程序运行您的程序提供一定的可信度。只有通过程序提供一定的可信度。只有通过 JDBC 驱动程序测试驱动程序测试包的驱动程序才被认为是符合包的驱动程序才被认为是符合 JDBC 标准标准TM 的。的。 JDBC-ODBC 桥。桥。JDBC-ODBC 桥使桥使 ODBC 驱动程序可被用作驱动程序可被用作 JDBC 驱驱动程序。它的实现为动程序。它的实现为 JDBC 的快速发展提供了一条途径,的快速发展提供了一条途径,其长远目标提供一种访问某些不常见的其长远目标提供一种访问某些不常见的 DBMS(如果对(如果对这些不常见的这些不常见的 DBMS 未实

33、现未实现 JDBC) 的方法。的方法。9.1.5 JDBC 驱动程序的类型驱动程序的类型我们目前所知晓的我们目前所知晓的 JDBC 驱动程序可驱动程序可分为以下四个种类:分为以下四个种类:JDBC-ODBC 桥加桥加 ODBC 驱动程序:驱动程序:JavaSoft 桥产品利用桥产品利用 ODBC 驱动程序提供驱动程序提供 JDBC 访问。注意,必须将访问。注意,必须将 ODBC 二进制代码二进制代码(许多情况下还包括数据库客户机代码)加(许多情况下还包括数据库客户机代码)加载到使用该驱动程序的每个客户机上。因此,载到使用该驱动程序的每个客户机上。因此,这种类型的驱动程序最适合于企业网(这种这种

34、类型的驱动程序最适合于企业网(这种网络上客户机的安装不是主要问题),或者网络上客户机的安装不是主要问题),或者是用是用 Java 编写的三层结构的应用程序服务编写的三层结构的应用程序服务器代码。器代码。本地本地 API - 部份用部份用 Java 来编写的驱动来编写的驱动程序:程序: 这种类型的驱动程序把客户机这种类型的驱动程序把客户机 API 上的上的 JDBC 调用转换为调用转换为 Oracle、Sybase、Informix、DB2 或其它或其它 DBMS 的的调用。注意,象桥驱动程序一样,这种调用。注意,象桥驱动程序一样,这种类型的驱动程序要求将某些二进制代码类型的驱动程序要求将某些二

35、进制代码加载到每台客户。加载到每台客户。JDBC 网络纯网络纯 Java 驱动程序:这种驱动程序将驱动程序:这种驱动程序将 JDBC 转换为与转换为与 DBMS 无关的网络协议,之后这种协议又被某无关的网络协议,之后这种协议又被某个服务器转换为一种个服务器转换为一种 DBMS 协议。这种网络服务器中间协议。这种网络服务器中间件能够将它的纯件能够将它的纯 Java 客户机连接到多种不同的数据库上。客户机连接到多种不同的数据库上。所用的具体协议取决于提供者。通常,这是最为灵活的所用的具体协议取决于提供者。通常,这是最为灵活的 JDBC 驱动程序。有可能所有这种解决方案的提供者都提驱动程序。有可能所

36、有这种解决方案的提供者都提供适合于供适合于 Intranet 用的产品。为了使这些产品也支持用的产品。为了使这些产品也支持 Internet 访问,它们必须处理访问,它们必须处理 Web 所提出的安全性、通所提出的安全性、通过防火墙的访问等方面的额外要求。几家提供者正将过防火墙的访问等方面的额外要求。几家提供者正将 JDBC 驱动程序加到他们现有的数据库中间件产品中。驱动程序加到他们现有的数据库中间件产品中。本地协议纯本地协议纯 Java 驱动程序:这种类型的驱动程序将驱动程序:这种类型的驱动程序将 JDBC 调用直接转换为调用直接转换为DBMS 所使用的网络协议。这将允许所使用的网络协议。这

37、将允许从客户机机器上直接调用从客户机机器上直接调用 DBMS 服务器,是服务器,是 Intranet 访问访问的一个很实用的解决方法。由于许多这样的协议都是专用的一个很实用的解决方法。由于许多这样的协议都是专用的,因此数据库提供者自己将是主要来源,有几家提供者的,因此数据库提供者自己将是主要来源,有几家提供者已在着手做这件事了。最后,我们预计第已在着手做这件事了。最后,我们预计第 3、4 类驱动程类驱动程序将成为从序将成为从 JDBC 访问数据库的首选方法。第访问数据库的首选方法。第1、2 类驱动类驱动程序在直接的纯程序在直接的纯 Java 驱动程序还没有上市前将会作为过渡驱动程序还没有上市前

38、将会作为过渡方案来使用。对第方案来使用。对第 1、2 类驱动程序可能会有一些变种,类驱动程序可能会有一些变种,这些变种要求有连接器,但通常这些是更加不可取的解决这些变种要求有连接器,但通常这些是更加不可取的解决方案。第方案。第 3、4 类驱动程序提供了类驱动程序提供了 Java 的所有优点,包括的所有优点,包括自动安装(例如,通过使用自动安装(例如,通过使用 JDBC 驱动程序的驱动程序的 applet applet来下载该驱动程序)。来下载该驱动程序)。9.2 JDBC常用类和方法常用类和方法9.2.1四种驱动程序概念四种驱动程序概念JDBC-ODBC Bridge 桥接器型的驱动程序,这类

39、驱动程序的特色是必须桥接器型的驱动程序,这类驱动程序的特色是必须在使用者端的计算机上事先安装好在使用者端的计算机上事先安装好ODBC驱动程序,驱动程序,然后通过然后通过JDBC-ODBC的调用方法,进而通过的调用方法,进而通过ODBC来来存取数据库。存取数据库。作为作为JDK1.1后的一部分,是后的一部分,是sun.jdbc.odbc包的一部分包的一部分 Application-JDBC-ODBC Bridge-JDBC-ODBC Library-ODBC Driver-Database 适用于快速的原型系统,没有提供适用于快速的原型系统,没有提供JDBC驱动的数据驱动的数据库如库如Acces

40、s JDBC-Native API Bridge 也是桥接器驱动程序之一,这类驱动程序也必须先在也是桥接器驱动程序之一,这类驱动程序也必须先在使用者计算机上先安装好特定的驱动程序(类似使用者计算机上先安装好特定的驱动程序(类似ODBC),然后通过),然后通过JDBC-Native API桥接器的转换,把桥接器的转换,把Java API调用转换成特定驱动程序的调用方法,进而存调用转换成特定驱动程序的调用方法,进而存取数据库。取数据库。 利用开发商提供的本地库来直接与数据库通信。利用开发商提供的本地库来直接与数据库通信。 Application-JDBC Driver-Native Databas

41、e library-Database 比比A类性能略好。类性能略好。 JDBC-middleware 这类型的驱动程序最大的好处就是省去了在使用者计算机上这类型的驱动程序最大的好处就是省去了在使用者计算机上安装任何驱动程序的麻烦,只需在服务器端安装好安装任何驱动程序的麻烦,只需在服务器端安装好middleware,而,而middleware会负责所有存取数据库必要的转会负责所有存取数据库必要的转换。换。 Application-Jdbc Driver-java middleware-JDBC Driver-Database 具有最大的灵活性,通常由那些非数据库厂商提供,是四种具有最大的灵活性,

42、通常由那些非数据库厂商提供,是四种类型中最小的。类型中最小的。 Pure JDBC driver这类型的驱动程序是最成熟的这类型的驱动程序是最成熟的JDBC驱动程序,不但无需在使驱动程序,不但无需在使用者计算机上安装任何额外的驱动程序,也不需要在服务器用者计算机上安装任何额外的驱动程序,也不需要在服务器端安装任何中介程序端安装任何中介程序(middleware),所有存取数据库的操作,所有存取数据库的操作,都直接由驱动程序来完成。都直接由驱动程序来完成。 Application-Jdbc driver-database engine-database 最高的性能,通过自己的本地协议直接与数据库

43、引最高的性能,通过自己的本地协议直接与数据库引擎通信,具备在擎通信,具备在Internet装配的能力。装配的能力。9.2.2 常用的常用的JDBC类与方法类与方法 DriverManager类:类: 负责管理负责管理JDBC驱动程序。使用驱动程序。使用JDBC驱动程序之前,驱动程序之前,必须先将驱动程序加载并向必须先将驱动程序加载并向DriverManager注册后注册后才可以使用,同时提供方法来建立与数据库的连才可以使用,同时提供方法来建立与数据库的连接。接。 方法:方法: Class.forName(String driver); /加载注册驱动程序加载注册驱动程序 static Conn

44、ection getConnection(String url,String user,String password) throws SQLException; /取得对数据库的连接取得对数据库的连接 Static Driver getDriver(String url) throws SQLExcetion; /在已经向在已经向DriverManager注册的驱动程序中寻找一个注册的驱动程序中寻找一个能够打开能够打开url所指定的数据库的驱动程序所指定的数据库的驱动程序 Connection类类 负责维护负责维护JSP/JAVA数据库程序和数据库之间数据库程序和数据库之间的联机。可以建立三

45、个非常有用的类对象。的联机。可以建立三个非常有用的类对象。方法:方法: Statement createStatement() throws SQLException; /建立建立Statement类对象类对象 Statement createStatement(int resultSetType,int resultSetConcurrency) throws SQLException; / 建立建立Statement类对象类对象 resultSetType值值 TYPE_FORWARD_ONLY 结果集不可滚动结果集不可滚动 TYPE_SCROLL_INSENSITIVE 结果集可滚动,不

46、反映数据库的结果集可滚动,不反映数据库的变化变化 TYPE_SCROLL_SENSITIVE 结果集可滚动,反映数据库的变结果集可滚动,反映数据库的变化化 resultSetConcurrency值值 CONCUR_READ_ONLY 不能用结果集更新数据不能用结果集更新数据 CONCUR_UPDATABLE 能用结果集更新数据能用结果集更新数据 JDBC2.0中才支持滚动的结果集,而且可以对数据进行更新中才支持滚动的结果集,而且可以对数据进行更新 PreparedStatement prepareStatement(String sql) throws SQLException; /建立建立

47、PreparedStatement类对象类对象 boolean getAutoCommit() throws SQLException /返回返回Connection类对象的类对象的AutoCommit状态状态 void setAutoCommit(boolean autoCommit) throws SQLException /设定设定Connection类对象的类对象的AutoCommit状态状态 void commit() throws SQLException /确定执行对数据确定执行对数据库新增、删除或修改记录的操作库新增、删除或修改记录的操作 void rollback() thr

48、ows SQLException /取消执行取消执行对数据库新增、删除或修改记录的操作对数据库新增、删除或修改记录的操作 void close() throws SQLException /结束结束Connection对象对数据库的联机对象对数据库的联机 boolean isClosed() throws SQLException /测试是测试是否已经关闭否已经关闭Connection类对象对数据库的联机类对象对数据库的联机 Statement类类 通过通过Statement类所提供的方法,可以利用标准的类所提供的方法,可以利用标准的SQL命令,对数据库直接新增、删除或修改操作命令,对数据库直

49、接新增、删除或修改操作 方法:方法: ResultSet executeQuery(String sql) throws SQLException /使用使用SELECT命令对数据库进行查询命令对数据库进行查询 int executeUpdate(String sql) throws SQLException /使用使用INSERTDELETEUPDATE对数据库进行新增、删除对数据库进行新增、删除和修改操作。和修改操作。 void close() throws SQLException /结束结束Statement类对类对象对数据库的联机象对数据库的联机 例例1: access.jsp% t

50、ry String url=jdbc:odbc:product ; Connection conn; java.sql.Statement st; /java.sql.DatabaseMetaData dm;Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); conn=DriverManager.getConnection(url,); out.println(Join Success); st=conn.createStatement(); /dm=conn.getMetaData(); ResultSet rs=st.executeQuery(sele

51、ct * from Products); while (rs.next() out.println(rs.getString(name)+); catch (Exception ex ) ex.printStackTrace(); /out.println(dm.getDriverVersion()+); % PreparedStatement类类 PreparedStatement类和类和Statement类的不同之处在类的不同之处在于于PreparedStatement类对象会将传入的类对象会将传入的SQL命令事命令事先编好等待使用,当有单一的先编好等待使用,当有单一的SQL指令要多次执行

52、指令要多次执行时,用时,用PreparedStatement类会比类会比Statement类有效类有效率率方法:方法: ResultSet executeQuery() throws SQLException /使用使用SELECT命令对数据库进行查询命令对数据库进行查询 int executeUpdate() throws SQLException /使用使用INSERTDELETEUPDATE对数据库进对数据库进行新增、删除和修改操作。行新增、删除和修改操作。void setInt(int parameterIndex,int x) throws SQLException /设定整数类型数

53、值给设定整数类型数值给PreparedStatement类对类对象的象的IN参数参数 void setFloat(int parameterIndex,float x) throws SQLException /设定浮点数类型数值给设定浮点数类型数值给PreparedStatement类类对象的对象的IN参数参数void setNull(int parameterIndex,int sqlType) throws SQLException /设定设定NULL类型数值给类型数值给PreparedStatement类对象的类对象的IN参数参数 void setString(int paramete

54、rIndex,String x) throws SQLException /设定字符串类型数值给设定字符串类型数值给PreparedStatement类对象的类对象的IN参数参数 void setDate(int parameterIndex,Date x) throws SQLException /设定日期类型数值给设定日期类型数值给PreparedStatement类对象的类对象的IN参参数数 void setTime(int parameterIndex,Time x) throws SQLException /设定时间类型数值给设定时间类型数值给PreparedStatement类对象

55、的类对象的IN参数参数 DatabaseMetaData类类 DatabaseMetadata类保存了数据库的所有特性,并且类保存了数据库的所有特性,并且提供许多方法来取得这些信息。提供许多方法来取得这些信息。 方法:方法: String getDatabaseProductName() throws SQLException /取得数据库名称取得数据库名称 String getDatabaseProductVersion() throws SQLException /取得数据库版本代号取得数据库版本代号 String getDriverName() throws SQLException /

56、取得取得JDBC驱动程序的名称驱动程序的名称 String getDriverVersion() throws SQLException /取得取得JDBC驱动程序的版本代号驱动程序的版本代号 String getURL() throws SQLException /取得连接数据库的取得连接数据库的JDBC URL String getUserName() throws SQLException /取得登录数据库的使用者帐号取得登录数据库的使用者帐号 ResultSet类类 负责存储查询数据库的结果。并提供一系列的方法对数负责存储查询数据库的结果。并提供一系列的方法对数据库进行新增、删除和修改

57、操作。也负责维护一个记录指据库进行新增、删除和修改操作。也负责维护一个记录指针(针(Cursor),记录指针指向数据表中的某个记录,通过),记录指针指向数据表中的某个记录,通过适当的移动记录指针,可以随心所欲的存取数据库,加强适当的移动记录指针,可以随心所欲的存取数据库,加强程序的效率。程序的效率。方法:方法: boolean absolute(int row) throws SQLException /移动记录移动记录指针到指定的记录指针到指定的记录void beforeFirst() throws SQLException /移动记录指针到移动记录指针到第一笔记录之前第一笔记录之前 voi

58、d afterLast() throws SQLException /移动记录指针移动记录指针到最后一笔记录之后到最后一笔记录之后 boolean first() throws SQLException /移动记录指针移动记录指针到第一笔记录到第一笔记录 boolean last() throws SQLException /移动记录指针移动记录指针到最后一笔记录到最后一笔记录boolean next() throws SQLException /移动记录指针移动记录指针到下一笔记录到下一笔记录 boolean previous() throws SQLException /移动记录移动记录指

59、针到上一笔记录指针到上一笔记录 void deleteRow() throws SQLException /删除记录指针删除记录指针指向的记录指向的记录 void moveToInsertRow() throws SQLException /移动记移动记录指针以新增一笔记录录指针以新增一笔记录 void moveToCurrentRow() throws SQLException /移动移动记录指针到被记忆的记录记录指针到被记忆的记录 void insertRow() throws SQLException /新增一笔记录新增一笔记录到数据库中到数据库中 void updateRow() th

60、rows SQLException /修改数据库修改数据库中的一笔记录中的一笔记录 void update类型类型(int columnIndex,类类型型 x) throws SQLException /修改指定字段的值修改指定字段的值 int get类型类型(int columnIndex) throws SQLException /取取得指定字段的值得指定字段的值 ResultSetMetaData getMetaData() throws SQLException /取得取得ResultSetMetaData类对象类对象 ResultSetMetaData类类 ResultSetMet

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论