JDBC-ODBC驱动程序 可从Sun的Java网站( http://java.sun.com )轻松地找到并下载。在您扩充并安装了这个驱动程序后,必须执行下列步骤:
· JDBC驱动程序的类型
Java 程序连接数据库的方法实际上有四种:如果您希望编写代码来处理 PC 客户机数据库,如 dBase 、 Foxbase 或 Access ,则您可能会使用第一种方法,并且拥有用户机器上的所有代码。更大的客户机 - 服务器数据库产品(如 IBM 的 DB2 )已提供了第 3 级别的驱动程序。
· 两层模型和三层模型
当数据库和查询它的应用程序在同一台机器上,而且没有服务器代码的干预时,我们将生成的程序称为 两层模型 。一层是应用程序,而另一层是数据库。在 JDBC-ODBC 桥系统中通常是这种情况。当一个应用程序或applet调用服务器,服务器再去调用数据库时,我们称其为 三层模型 。当您调用称为“服务器”的程序时通常是这种情况。
· 编写JDBC代码访问数据库
现在,我们将开始看一下如何编写 Java 程序来访问数据库。我们要使用的数据库是一个称为 groceries.mdb 的 Microsoft Access 数据库。此数据库中的数据由三个本地杂货店中一些常见商品的价格组成。食品表如下所示:
FoodKey | FoodName |
1 | Apples |
2 | Oranges |
3 | Hamburger |
4 | Butter |
5 | Milk |
6 | Cola |
7 | Greenbeans |
杂货店表如下所示:
StoreKey | StoreName |
1 | Stop andShop |
2 | VillageMarket |
3 | Waldbaum's |
杂货店定价表仅由这三个表格中的键值和价格组成:
FSKey | StoreKey | FoodKey | Price |
1 | 1 | 1 | $0.27 |
2 | 2 | 1 | $0.29 |
3 | 3 | 1 | $0.33 |
4 | 1 | 2 | $0.36 |
5 | 2 | 2 | $0.29 |
6 | 3 | 2 | $0.47 |
7 | 1 | 3 | $1.98 |
8 | 2 | 3 | $2.45 |
9 | 3 | 3 | $2.29 |
10 | 1 | 4 | $2.39 |
11 | 2 | 4 | $2.99 |
12 | 3 | 4 | $3.29 |
13 | 1 | 5 | $1.98 |
14 | 2 | 5 | $1.79 |
15 | 3 | 5 | $1.89 |
16 | 1 | 6 | $2.65 |
17 | 2 | 6 | $3.79 |
18 | 3 | 6 | $2.99 |
19 | 1 | 7 | $2.29 |
20 | 2 | 7 | $2.19 |
21 | 3 | 7 | $1.99 |
· 用ODBC注册您的数据库
在 Windows 95 或 NT 环境下访问 ODBC 数据库之前,必须使用控制面板中的 ODBC 驱动程序对它进行注册。在 Windows 95 环境下,就是 “ 控制面板 ” 程序中的 ODBC 图标。在 Windows NT 环境下,您会在 “ 开始 ” 菜单中找到此程序。(如果找不到,您需要安装上述的 ODBC 驱动程序,即 WX1350.exe )。
双击ODBC图标,然后单击“添加”,如图1所示。然后选择数据库驱动程序(此处使用MicrosoftAccess),然后单击“确定”。在“数据源名”和“描述”中分别键入数据源名称(Groceries)和数据库说明(Groceryprices)(这两项都不需要和文件名相关),然后单击“选取”,找到数据库,并选择该数据库。找到该数据库后,屏幕将如图2所示。单击“确定”,然后单击“关闭”来关闭面板。
图1:ODBC控制面板设置屏幕。
图2:在ODBC控制面板中选择数据库和说明。
· 连接数据库
所有与数据库有关的对象和方法都在 java.sql 包中,因此在使用 JDBC 的程序中必须加入 "import java.sql.* " 。 JDBC 要连接 ODBC 数据库,您必须首先加载 JDBC-ODBC 桥驱动程序
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); |
String url = "jdbc:odbc:Grocery prices"; Connection con = DriverManager.getConnection(url); |
请注意,您使用的数据库名是您在 ODBC 设置面板中输入的 “ 数据源 ” 名称。
URL语法可能因数据库类型的不同而变化极大。
jdbc: subprotocol : subname |
jdbc:bark//doggie/elliott |
jdbc:bark//doggie/elliot;UID=GoodDog;PWD=woof |