搞定J2EE核心技术与企业应用
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人

7.3 各种驱动程序实例

通过前面讲解的内容可以知道JDBC程序分为Java到数据库协议、Java到本地API、JDBC-ODBC桥和Java到网络协议,关于JDBC程序的工作原理如图7.13所示。

图7.13 JDBC的工作原理

7.3.1 利用Java到数据库协议方式连接数据库

当利用Java到数据库协议方式来操作数据库时,会利用数据库相关的协议把对驱动程序的请求直接发送给数据库,该协议实际上就是包含在驱动程序中纯Java类。

本小节将演示如何利用oracle:thin子协议来操作Oracle数据库,具体步骤如下:

01 配置开发环境,引入与Oracle数据库相对应的JDBC。首先复制对应的驱动程序,然后在Package Explorer视图中用鼠标右键单击jdbc项目,在弹出的快捷菜单中选择“Paste”,就完成了环境的配置。

02 连接和操作Oracle数据库,文件JDBCTest.java通过oracle:thin子协议显示出Oracle数据库中的employee表格中的数据,具体内容如下:

      //******* JDBCTest.java **************
        public static void main(String[] args) {
              try{
                Class.forName("oracle.jdbc.driver.OracleDriver");   //加载JDBC驱动
                //连接数据库
                Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:
                1521:orcl","scott","root");
                Statement stmt=conn.createStatement();         //获取陈述对象
                //获取结果集
                ResultSet rs = stmt.executeQuery("select * from employee");
                System.out.println("记录内容:");
                System.out.println("\tID号\t姓名\t电话号码" );
                //遍历结果集
                while(rs.next()){
                    System.out.print("\t" + rs.getInt(1));
                    System.out.print("\t" + rs.getString(2));
                    System.out.println("\t" + rs.getInt(3));
                    System.out.println();
                }
                rs.close();
                stmt.close();
                conn.close();
              }catch(Exception e){
              e.printStackTrace();
          }
          }
      }

代码说明:

当程序通过DriverManager.getConnection()方法连接Oracle数据库时,其参数jdbc:oracle:thin:@localhost:1521:orcl中使用的子协议名为oracle:thin,子名称中localhost为主机名、1521为Oracle服务器端口号、orcl为数据库名。

03 编译和运行该程序后,结果如图7.14所示。

图7.14 运行结果

7.3.2 利用Java到本地API方式连接数据库

当利用Java到本地API方式来操作数据库时,首先会通过调用本地的API(数据库客户端提供的API)连接到相应数据库客户端,然后再通过该客户端连接到相对应的数据库。在具体编写代码时,只需把调用驱动程序的代码转换成调用本地API的代码即可。

本小节将演示如何利用OCI(Oracle Call Interface)子协议来操作Oracle数据库,所谓OCI方式就是应用程序先连接Oracle数据库的客户端,然后在通过该客户端连接数据库,因此该方式属于Java到本地API方式,具体步骤如下:

01 Oracle客户端配置,该功能可以通过3种方式来实现:利用客户端工具Net Configuration Assistant;利用Net Manager图形化工具或修改“tnsnames.ora”数据库配置文件。

下面将通过Net Configuration Assistant工具来实现本地Net服务名配置,首先打开Net Configuration Assistant工具,在该工具的欢迎界面(如图7.15所示)中选择“本地Net服务名配置”单选按钮,单击“下一步”按钮,进入“服务名配置”对话框(如图7.16所示),在该对话中选择“添加”单选按钮,单击“下一步”按钮,进入“服务名配置,服务名”对话框(如图7.17所示),在该对话框中需要为服务名选项填写安装Oracle服务器的时产生的SID(系统标识号),然后单击“下一步”按钮,进入“服务名配置,请选择协议”对话框(如图7.18所示),在该对话框中保持默认设置,单击“下一步”按钮,进入“服务名配置,TCP/IP协议”对话框(如图7.19所示),在该对话框中需要对主机和端口号进行设置,该项目因为在本地计算机上所以填写的是“127.0.0.1”,所以这里端口号保持默认即可。至此,基本完成Oracle客户端配置,对于其他的对话框保持默认即可。

图7.15 欢迎界面

图7.16 服务名配置

图7.17 添加服务名

图7.18 选择协议

图7.19 配置协议

02 连接和操作Oracle数据库,文件OCITest.java通过OCI子协议显示出Oracle数据库中的employee表格中的数据,具体内容如下所示。

      //******* OCITest.java **************
      public class OCITest{
          public static void main(String args[]){
              try{
                Class.forName("oracle.jdbc.driver.OracleDriver");   //加载驱动
                //连接数据库
                Connection conn = DriverManager.getConnection("jdbc:oracle:oci:@orcl","scott","root");
                Statement stmt=conn.createStatement();         //获取陈述对象
                //获取运行结果
                ResultSet rs = stmt.executeQuery("select * from guestbook");
                System.out.println("记录内容:");
                System.out.println("\tID号\t姓名\t电话号码" );
              while(rs.next()){
                  System.out.print("\t" + rs.getInt(1));
                  System.out.print("\t" + rs.getString(2));
                  System.out.println("\t" + rs.getInt(3));
                  System.out.println();
              }
              rs.close();
              stmt.close();
              conn.close();
          }catch(Exception e){
              e.printStackTrace();
          }
      }
      }

代码说明:

当程序通过DriverManager.getConnection()方法连接Oracle数据库时,其参数“jdbc:oracle:oci:@orcl”中使用的子协议名为oracle:oci,子名称中@后面必须为刚才配置好的本地Net服务名。

03 该程序如果想运行成功,必须要加入与Oracle数据库相对应的JDBC驱动程序。编译和运行该程序后,其运行结果如图7.20所示。

图7.20 运行结果

7.3.3 利用JDBC-ODBC方式连接数据库

当利用JDBC-ODBC桥驱动程序来操作数据库时,该驱动程序并不是直接操作数据库驱动程序,而是调用JDBC-ODBC桥驱动程序操作ODBC驱动程序,进而连接各种数据库。其详细过程是:应用程序中调用JDBC-ODBC桥驱动程序的指令在“驱动管理器”的中转下交由JDBC-ODBC桥驱动程序处理,经过处理后这些指令格式就会转成ODBC的指令格式。这些指令会自动通过ODBC的驱动程序来利用底层相应的数据库驱动程序来访问对应数据库,具体过程如图7.21所示。

图7.21 JDBC-ODBC桥驱动程序使用

注意:对于开发人员来说,图7.21中最后3步是由Windows系统自动封装成为ODBC数据源,不需要进行相应的编程。

下面将演示如何利用JDBC-ODBC桥驱动程序操作数据库,具体步骤如下:

01 创建ODBC数据源,微软的Windows系统全方位支持ODBC数据源。首先通过双击管理工具中“数据源(ODBC)”图标打开ODBC数据源管理器(如图7.22所示)。然后在“用户DSN”标签中单击“添加”按钮,打开“创建新数据源”对话框(如图7.23所示),在该对话框中为操作的数据源选择相对应的驱动程序,因为该项目操作Excel,所以选择了“Driver do Microsoft Excel(*.xls)”选项。接着单击“完成”按钮就会出现关于ODBC Microsoft Excel安装的对话框,在该对话框中除了要自己定义一个数据源名外,还需要通过“选择工作簿”按钮来设置数据源Excel的路径,设置结果如图7.24所示。最后单击“确定”按钮返回ODBC数据源管理器(如图7.25所示),在该对话框中多出了一个名为“ExcelTest”的数据源记录。至此,ODBC数据源就创建成功了。

图7.22 ODBC数据源管理器

图7.23 创建数据源

图7.24 ODBC Microsoft Excel安装

图7.25 ODBC数据源管理器

02 连接和操作ODBC数据源,文件JDBC_ODBCTest.java通过JDBC-ODBC桥驱动程序来显示Excel表格中的数据,具体内容如下:

      //******* JDBC_ODBCTest.java **************
      import java.sql.*;
      public class JDBC_ODBCTest{
        public static void main(String args[]){
        String drv="sun.jdbc.odbc.JdbcOdbcDriver";           //创建驱动连接字符串
              try{
                Class.forName(drv);                      //加载驱动
              //获取连接
              Connection con = DriverManager.getConnection("jdbc:odbc:ExcelTest", "", "");
              Statement stmt=con.createStatement();        //获取陈述对象
              ResultSet rs=stmt.executeQuery("select * from [Sheet1$]");
              System.out.println("记录内容:");
              System.out.println("\tID号\t姓名\t电话号码" );
              while(rs.next()){
                  System.out.print("\t" + rs.getInt(1));
                  System.out.print("\t" + rs.getString(2));
                  System.out.print("\t" + rs.getInt(3));
                  System.out.println();
              }
              rs.close();
              stmt.close();
              con.close();
          }catch(Exception e){
              e.printStackTrace();
          }
      }
      }

代码说明:

● 当程序通过Class.forName()方法加载驱动程序类时,其参数必须为sun.jdbc.odbc.JdbcOdbcDriver,即JDBC-ODBC桥驱动程序。

● 当程序通过DriverManager.getConnection()方法连接ODBC数据源时,其第一个参数中协议与子协议名必须为jdbc和odbc,而子名称是确定的必须为ExcelTest数据源名。第二个和第三个参数用来设置用户名和密码,当它们为空时可以设置为空字符串。

注意:在早期由于经常会使用JDBC-ODBC桥驱动程序操作数据库,所以Sun公司在JDK中就提供了JDBC-ODBC桥驱动程序,因此在程序中不需要加入JDBC-ODBC桥驱动程的架包。

03 编译和运行该程序后,其运行结果如图7.26所示。

图7.26 运行结果