📄 intro.doc.html
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN">
<html>
<head>
<meta HTTP-EQUIV="Content-Type" CONTENT="text/html; CHARSET=gb2312">
<title></title>
</head>
<body bgcolor="#ffffff">
<table width="600">
<tr>
<td><font size="-1"><a href="introTOC.doc.html">目录</a> | <a href="copyright.doc.html">上一页</a>
| <a href="connection.doc.html">下一页</a> </font></td>
<td align="right"><i>JDBC<sup><font size="-2">TM</font></sup> 指南:入门</i></td>
</tr>
</table>
<hr>
<p><br>
<a name="997449"></a> </p>
<h1>1 - 简介 </h1>
<p>本简介是从《<em>JDBC<font size="-1"><sup>TM</sup></font> Database Access from
Java<font size="-1"><sup>TM</sup></font>: A Tutorial and Annotated Reference</em>
》这本书中摘引来的。JavaSoft
目前正在准备这本书。这是一本教程,同时也是 JDBC
的重要参考手册,它将作为 Java 系列的组成部份在 1997 年春季由
Addison-Wesley 出版公司出版。</p>
<p><a name="1005262"></a> </p>
<h2>1.1 什么是 JDBC<font size="-1"><sup>TM</sup></font>?</h2>
<p>JDBC<font size="-1"><sup>TM</sup></font> 是一种用于执行 SQL 语句的 Java<font
size="-1"><sup>TM</sup></font> API(有意思的是,JDBC
本身是个商标名而不是一个缩写字;然而,JDBC 常被认为是代表 “Java
数据库连接 (Java Database Connectivity)”)。它由一组用 Java
编程语言编写的类和接口组成。JDBC 为工具/数据库开发人员提供了一个标准的
API,使他们能够用纯 Java API 来编写数据库应用程序。</p>
<p>有了 JDBC,向各种关系数据库发送 SQL
语句就是一件很容易的事。换言之,有了 JDBC API,就不必为访问
Sybase 数据库专门写一个程序,为访问 Oracle
数据库又专门写一个程序,为访问 Informix
数据库又写另一个程序,等等。您只需用 JDBC API
写一个程序就够了,它可向相应数据库发送 SQL 语句。而且,使用
Java
编程语言编写的应用程序,就无须去忧虑要为不同的平台编写不同的应用程序。将
Java 和 JDBC
结合起来将使程序员只须写一遍程序就可让它在任何平台上运行。</p>
<p><a name="1005727"></a>Java
具有坚固、安全、易于使用、易于理解和可从网络上自动下载等特性,是编写数据库应用程序的杰出语言。所需要的只是
Java 应用程序与各种不同数据库之间进行对话的方法。而 JDBC
正是作为此种用途的机制。</p>
<p><a name="1005728"></a>JDBC 扩展了 Java 的功能。例如,用 Java 和 JDBC API
可以发布含有 applet 的网页,而该 applet
使用的信息可能来自远程数据库。企业也可以用 JDBC 通过 Intranet
将所有职员连到一个或多个内部数据库中(即使这些职员所用的计算机有
Windows、 Macintosh 和 UNIX
等各种不同的操作系统)。随着越来越多的程序员开始使用 Java
编程语言,对从 Java 中便捷地访问数据库的要求也在日益增加。</p>
<p><a name="1005729"></a>MIS 管理员们都喜欢 Java 和 JDBC
的结合,因为它使信息传播变得容易和经济。企业可继续使用它们安装好的数据库,并能便捷地存取信息,即使这些信息是储存在不同数据库管理系统上。新程序的开发期很短。安装和版本控制将大为简化。程序员可只编写一遍应用程序或只更新一次,然后将它放到服务器上,随后任何人就都可得到最新版本的应用程序。对于商务上的销售信息服务,
Java 和 JDBC 可为外部客户提供获取信息更新的更好方法。</p>
<p><a name="1005731"></a> </p>
<h3>1.1.1 JDBC 的用途是什么?</h3>
<p>简单地说,JDBC 可做三件事: </p>
<pre><a name="1005733"></a>
</pre>
<ul>
<li>与数据库建立连接, <a name="1005735"></a> </li>
<li>发送 SQL 语句, <a name="1005736"></a> </li>
<li>处理结果。<pre><a name="1005737"></a>
</pre>
</li>
</ul>
<p><a name="1005738"></a>下列代码段给出了以上三步的基本示例: </p>
<pre><a name="1005739"></a> Connection con = DriverManager.getConnection (
<a
name="1005740"></a> "jdbc:odbc:wombat", "login", "password");
<a
name="1005741"></a> Statement stmt = con.createStatement();
<a name="1005742"></a> ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table1");
<a
name="1005743"></a> while (rs.next()) {
<a name="1005744"></a> int x = rs.getInt("a");
<a
name="1005745"></a> String s = rs.getString("b");
<a name="1005746"></a> float f = rs.getFloat("c");
<a
name="1005747"></a> }
</pre>
<p><a name="1005749"></a> </p>
<h3>1.1.2 JDBC 是一种低级 API ,是高级 API 的基础</h3>
<p><a name="1005750"></a>JDBC
是个“低级”接口,也就是说,它用于直接调用 SQL
命令。在这方面它的功能极佳,并比其它的数据库连接 API
易于使用,但它同时也被设计为一种基础接口,在它之上可以建立高级接口和工具。高级接口是“对用户友好的”接口,它使用的是一种更易理解和更为方便的
API,这种 API 在幕后被转换为诸如 JDBC
这样的低级接口。在编写本文时,正在开发两种基于 JDBC 的高级 API:
<ol>
<p><a name="1005751"></a></p>
<li>一种用于 Java 的嵌入式 SQL。至少已经有一个提供者计划编写它。DBMS
实现 SQL:一种专门设计来与数据库联合使用的语言。JDBC 要求 SQL
语句必须作为 String 传给 Java 方法。相反,嵌入式 SQL
预处理器允许程序员将 SQL 语句直接与 Java
混在一起使用。例如,可在 SQL 语句中使用 Java
变量,用以接受或提供 SQL 值。然后,嵌入式 SQL 预处理器将通过 JDBC
调用把这种 Java/SQL 的混合物转换为 Java。<a name="1005752"></a> </li>
<li>关系数据库表到 Java 类的直接映射。JavaSoft
和其它提供者都声称要实现该 API。在这种“对象/关系”映射中,表中的每行对应于类的一个实例,而每列的值对应于该实例的一个属性。于是,程序员可直接对
Java 对象进行操作;存取数据所需的 SQL
调用将在“掩盖下”自动生成。此外还可提供更复杂的映射,例如将多个表中的行结合进一个
Java 类中。</li>
</ol>
<p><a name="1005753"></a>随着人们对 JDBC
的兴趣日益增涨,越来越多的开发人员一直在使用基于 JDBC
的工具,以使程序的编写更加容易。程序员也一直在编写力图使最终用户对数据库的访问变得更为简单的应用程序。例如,应用程序可提供一个选择数据库任务的菜单。任务被选定后,应用程序将给出提示及空白供填写执行选定任务所需的信息。所需信息输入后,应用程序将自动调用所需的
SQL 命令。在这样一种程序的协助下,即使用户根本不懂 SQL
的语法,也可以执行数据库任务。</p>
<p><a name="1005754"></a> </p>
<h3>1.1.3 JDBC 与 ODBC 和其它 API 的比较</h3>
<p><a name="1005755"></a>目前,Microsoft 的 ODBC(开放式数据库连接)API
可能是使用最广的、用于访问关系数据库的编程接口。它能在几乎所有平台上连接几乎所有的数据库。为什么
Java 不使用 ODBC? </p>
<p>对这个问题的回答是:Java 可以使用 ODBC,但最好是在 JDBC
的帮助下以 JDBC-ODBC
桥的形式使用,这一点我们稍后再说。现在的问题已变成:“为什么需要
JDBC”? 回答如下:
<ol>
<p><a name="1005757"></a></p>
<li>ODBC 不适合直接在 Java 中使用,因为它使用 C 语言接口。从 Java
调用本地 C
代码在安全性、实现、坚固性和程序的自动移植性方面都有许多缺点。<a
name="1005758"></a> </li>
<li>从 ODBC C API 到 Java API 的字面翻译是不可取的。例如,Java
没有指针,而 ODBC 却对指针用得很广泛(包括很容易出错的指针
"void *")。您可以将 JDBC 想象成被转换为面向对象接口的 ODBC,而面向对象的接口对
Java 程序员来说较易于接收。<a name="1005759"></a> </li>
<li>ODBC
很难学。它把简单和高级功能混在一起,而且即使对于简单的查询,其选项也极为复杂。相反,JDBC
尽量保证简单功能的简便性,而同时在必要时允许使用高级功能。<a
name="1005760"></a> </li>
<li>启用“纯 Java ”机制需要象 JDBC 这样的 Java API。如果使用 ODBC,就必须手动地将
ODBC 驱动程序管理器和驱动程序安装在每台客户机上。如果完全用
Java 编写 JDBC 驱动程序则 JDBC 代码在所有 Java
平台上(从网络计算机到大型机)都可以自动安装、移植并保证安全性。</li>
</ol>
<p><a name="1005761"></a>总之,JDBC API 对于基本的 SQL
抽象和概念是一种自然的 Java 接口。它建立在 ODBC
上而不是从零开始。因此,熟悉 ODBC 的程序员将发现 JDBC
很容易使用。JDBC 保留了 ODBC
的基本设计特征;事实上,两种接口都基于 X/Open SQL CLI(调用级接口)。它们之间最大的区别在于:JDBC
以 Java 风格与优点为基础并进行优化,因此更加易于使用。</p>
<p><a name="1005762"></a>最近,Microsoft 又引进了 ODBC 之外的新 API: RDO、
ADO 和 OLE DB。这些设计在许多方面与 JDBC
是相同的,即它们都是面向对象的数据库接口且基于可在 ODBC
上实现的类。但在这些接口中,我们未看见有特别的功能使我们要转而选择它们来替代
ODBC,尤其是在 ODBC
驱动程序已建立起较为完善的市场的情况下。它们最多也就是在 ODBC
上加了一种装饰而已。这并不是说 JDBC
不需要从其最初的版本再发展了;然而,我们觉得大部份的新功能应归入诸如前一节中所述的对象/关系映射和嵌入式
SQL 这样的高级 API。</p>
<p><a name="1005767"></a> </p>
<h3>1.1.4 两层模型和三层模型</h3>
<p><a name="1005768"></a>JDBC API
既支持数据库访问的两层模型,同时也支持三层模型。</p>
<p><a name="1005769"></a>在两层模型中,Java applet
或应用程序将直接与数据库进行对话。这将需要一个 JDBC
驱动程序来与所访问的特定数据库管理系统进行通讯。用户的 SQL
语句被送往数据库中,而其结果将被送回给用户。数据库可以位于另一台计算机上,用户通过网络连接到上面。这就叫做<i>客户机/服务器</i>配置,其中用户的计算机为客户机,提供数据库的计算机为服务器。网络可以是
Intranet(它可将公司职员连接起来),也可以是 Internet。<br>
<br>
<img src="intro.doc.anc.gif" width="230" height="163"><br>
</p>
<p><a name="1005784"></a> </p>
<p><a name="1005785"></a>在三层模型中,命令先是被发送到服务的“中间层”,然后由它将
SQL 语句发送给数据库。数据库对 SQL
语句进行处理并将结果送回到中间层,中间层再将结果送回给用户。MIS
主管们都发现三层模型很吸引人,因为可用中间层来控制对公司数据的访问和可作的的更新的种类。中间层的另一个好处是,用户可以利用易于使用的高级
API,而中间层将把它转换为相应的低级调用。最后,许多情况下三层结构可提供一些性能上的好处。<br>
<br>
<img src="intro.doc.anc1.gif" width="330" height="258"><br>
</p>
<p><a name="1005805"></a>到目前为止,中间层通常都用 C 或 C++
这类语言来编写,这些语言执行速度较快。然而,随着最优化编译器(它把
Java 字节代码转换为高效的特定于机器的代码)的引入,用 Java
来实现中间层将变得越来越实际。这将是一个很大的进步,它使人们可以充分利用
Java 的诸多优点(如坚固、多线程和安全等特征)。JDBC 对于从 Java
的中间层来访问数据库非常重要。</p>
<p><a name="1005806"></a> </p>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -