由于PL/SQL不能用来开发面向普通用户的应用程序,必须借助其他语言或开发工具。在Linux操作系统下应该用什么语言或开发工具来进行Oracle数据库应用的开发呢?
4. JDBC编程
在Linux下用JDBC访问Oracle数据库主要有以下几个技术要点:
(1) 注册Oracle的JDBC驱动。有两种方式,一种是调用class.forName方法:
Class.forName("oracle.jdbc.driver.OracleDriver");
另一种是调用DriverManager类的registerDriver方法:
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
(2) 获取Oracle数据库的连接。也有两种方式。一是调用OCI驱动程序,OCI驱动程序利用Java本地化接口(JNI),通过Oracle客户端软件与数据库进行通讯。
Connection conn=DriverManager.
getConnection("jdbc:oracle:oci8:@","test","test"); |
另一种方式是调用Thin驱动程序。Thin驱动程序是纯Java驱动程序,它直接与数据库进行通讯。
conn=DriverManager.getConnection
("jdbc:oracle:thin:@10.1.14.34:1521:MyDB","test","test"); |
为了获得最高的性能,Oracle公司建议在客户端软件的开发中使用OCI驱动程序。
(3) 建立Statament和结果集对象,执行SQL语句,结果返回到结果集。
Statement pstmt=conn.createStatement();
ResultSet rset= pstmt.executeQuery(query) |
(4) 处理结果集,显示数据。
以下是遍历student数据表的Java源程序Stu.java,源程序中包含了两种注册Oracle驱动的方式,以及OCI和Thin两种连接数据库的方法(因程序中不可能同时使用两种方法,所以另一种方法被注释)。
/* 导入Java类 */
import java.sql.*;
/* 主类 */
public class Stu
{
public static void main(String argv[]) throws SQLException
{
/* 声明并初始化变量 */
String query = new String("SELECT id,name,score FROM student");
String name;
int id,score;
Connection conn=null;
try{
/*第一种注册JDBC的Oracle驱动的方法*/
//Class.forName("oracle.jdbc.driver.OracleDriver");
/*第二种注册JDBC的Oracle驱动的方法*/
DriverManager.registerDriver
(new oracle.jdbc.driver.OracleDriver());
}catch(Exception e){
System.out.println("Could not load drive:"+e);
System.exit(-1);
}
/*利用Thin驱动程序获取Oracle连接*/
//conn=DriverManager.getConnection
("jdbc:oracle:thin:@10.1.14.34:1521:MyDB","test","test");
//System.out.println("Connected with THIN CLIENT!");
/*利用OCI驱动程序获取Oracle连接*/
conn=DriverManager.getConnection
("jdbc:oracle:oci8:@","test","test");
System.out.println("Connected with OCI8!\n");
/* 使用try ... catch抓取并处理例外 */
try {
Statement pstmt=conn.createStatement();
/* 执行SQL语句 */
ResultSet rset= pstmt.executeQuery(query);
/* 循环处理JDBC结果集的数据 */
while(rset.next()) {
id=rset.getInt(1);
name = rset.getString(2);
score=rset.getInt(3);
System.out.println("ID=" + id);
System.out.println("NAME=" + name);
System.out.println("SCORE=" + score);
System.out.println("---------------");
}
/* 关闭JDBC结果集 */
rset.close();
/* 关闭动态SQL语句 */
pstmt.close();
}
catch(SQLException e) {
System.out.println("出现SQL例外:" + e.getMessage());
}
conn.close();
}
}
编译、执行上述源程序,可显示出student表中所有记录。
$javac Stu.java
$java Stu |
5. 结束语
从Oracle公司的产品策略和发展趋势来看,Java将成为Oracle数据库最有力的工具。Oracle公司在Oracle 8i中引入JVM,并在Oracle 9i中已经发展得极为成熟。这使得我们不仅可以利用JDBC和SQLJ访问Oracle数据库,也可以在Oracle的PL/SQL中执行用Java编写的存储过程和函数,两者的结合是双向和无缝的。Java使Oracle正在成为一个平台无关的数据库,正如Oracle公司的发展目标所说的那样:没有操作系统,只有Oracle和Internet。