用SQLJ开发数据库
2007-11-11 04:17:57 来源:WEB开发网- ·数据库人员面试:sql server(WINDOWS平台上强大的数据库平台)常用测试
·Oracle(大型网站数据库平台)数据库客户端的安装和配置
·PHP连接数据库的方法(3)
·Oracle(大型网站数据库平台)数据库网络的安装和配置(1)
·用jsp(SUN企业级应用的首选)从数据库中读取图片并显示在网页
·[冷枫推荐]:数据库操作,内外联查询
·PHP中使用类对数据库进行操作
·图解MySQL(和PHP搭配之最佳组合)数据库的安装和操作 (1)
·InterBase 数据库函数库
·利用外部命令Oralce数据库导入导出
对于有输入参数的SQL语句,SQLJ类通常比等价的动态的SQL语句( JDBC)调用简短,因为SQLJ运用主机变量把参数传递到SQL语句中,当JDBC要求一个单独的语句把个个参数捆绑起来,检索每个结果。下面是一条SELECT语句的SQLJ代码片断:
String vName; int vSalary; String vJob; Java.sql.Timestamp vDate; ... #sql { SELECT Ename, Sal INTO :vName, :vSalary FROM Emp WHERE Job = :vJob and HireDate = :vDate }; |
下面是相同的SELECT语句的JDBC代码碎片:
String vName; int vSalary; String vJob; Java.sql.Timestamp vDate; stmt.setString(1, vJob); ResultSet rs = stmt.executeQuery(); vName = rs.getString(1); rs.close(); |
我们可以看到,直接在一个Java程序中嵌入SQL语句能够生成比JDBC更加简明易读的代码。因此,SQLJ在Java应用程序有数据库访问需要的时候,减少了开发时间和维修代价。SQLJ程序可以在同一个源文件中很容易地与JDBC代码相互作用来做到动态的SQL语句调用,或者你也可以在SQLJ语句中使用PL/SQL语句块来完成这个目的。此外,Oracle(大型网站数据库平台) 9i增加了在SQLJ代码直接支持动态SQL的功能。
Java ( SQLJ和JDBC)与Oracle(大型网站数据库平台)数据库中的PL/SQL比较:
Oracle(大型网站数据库平台)数据库应用程序中的使用的Java还不能够替代PL/SQL。Java和PL/SQL相辅相成,Java ( SQLJ/JDBC)有下列优于PL/SQL的地方:Java能够提供重要的性能优势,Java存储过程要快5到100倍,这主要取决于程序中使用的数学操作符和数据类型。理论上说,Java存储过程可以很容易的转化成运行在其它数据库上的存储过程。Java程序可以在一个复杂的应用程序的任何一层上配置∶在客户端上,在中间层的应用程序服务器上或者在数据库服务器本身中。Java ( SQLJ/JDBC)也同样“分享”了PL/SQL的不足之处:PL/SQL与Oracle(大型网站数据库平台)数据库服务器紧密地结合起来,Oracle(大型网站数据库平台)在近20年的时间中不断的改进PL/SQL,而Java只在1998年的时候才被引进Oracle(大型网站数据库平台) 8i。PL/SQL数据类型等价于Oracle(大型网站数据库平台)本地数据类型,所以不需要进行数据类型的换算。在另一方面,JDBC提出在Java代码和SQL语句之间插入一个普通的层,而SQLJ是又一个层。PL/SQL工作性能比Java好,因为是以数据库为中心编程:PL/SQL存储过程比Java程序快1.5倍(对于OLTP联机事务处理)到2.5倍(用于批处理)。此外,Java程序要使用比PL/SQL更多的CPU资源。CPU额外开销的增加可能是因为要进行一个比较长的编码过程以及从Oracle(大型网站数据库平台)到Java的额外的数据类型转换。
一个两者兼顾达到最好效果的解决方案
Oracle(大型网站数据库平台)提供了一个理想的环境用于利用PL/SQL和Java语言两者的优点。在一方面,PL/SQL程序可以调用SQLJ和JDBC存储过程,允许你构建基于组件的EJB和CORBA应用程序。现有的Java类库可以很容易地被利用,并通过使用PL/SQL调用规范来整合入数据库代码开发过程中。在另一方面,Java程序可以通过JDBC或者SQLJ调用PL/SQL存储过程,函数和匿名的程序块。我下面想一一详细介绍,SQLJ提供用于调用下面这些内容的语法:
存储过程:使用CALL操作符调用UpdateSalary程序∶
#sql { CALL UpdateSalary }; 函数:<0} {0>to call the GetName() function using the VALUES operator: <}0{>使用VALUES操作符调用GetName()函数∶<0} {0>String name; <}0{>String name;<0} #sql { name = { VALUES GetName() }; or by using the SET operator: String name; #sql { SET :name = GetName() }; {0>Anonymous PL/SQL blocks: <}0{>匿名的PL/SQL程序块∶<0} #sql { [DECLARE ...] BEGIN ... END; }; |
需要注意的是影响决定使用什么语言的因素,不仅由执行效果决定--说得更精确些,一个现今应用程序开发过程中的主要因素,而且由程序员劳动生产率、可获得的专家的意见和轻便性决定。幸亏对于数据库开发人员,不必在几种语言中选来选去,你可以很容易地把Java ( SQLJ和JDBC)与PL/SQL存储程序混合搭配进一个数据库来取得一个两者兼顾达到最好效果的解决方案。
更多精彩
赞助商链接