对于有输入参数的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存储程序混合搭配进一个数据库来取得一个两者兼顾达到最好效果的解决方案。
转载保留:http://www.qqread.com/sqlserver/d222106005.html相关专题
- 数据库专栏 (5150篇文章)
- 数据库处理专题 (8607篇文章)
- 城域网专题 (7812篇文章)
- 数据库安全技术专题 (13086篇文章)
- 数据库安装与卸载 (10507篇文章)
- Wlan组网----家庭专题 (4184篇文章)
- Linux数据库宝典 (13020篇文章)
- 数据库相关文章 (5150篇文章)
- SQL Server连接中常见错误解决方法 (99次浏览)
- SQL server7.0的远程连接问题 (90次浏览)
- SQL Server的文件恢复技术 (6次浏览)
- 用SQL Server 2005实现WebService (0次浏览)
- 用NetBeans5.0连接SQL Server2005数据库 (0次浏览)
- 使用NetBeans5.0连接SQL Server 2005数据库 (0次浏览)
- 如何使用SQL Server 2000中的XML功能一 (0次浏览)
- 访谈:SQL Server Everywhere仅仅是另一种数据 (0次浏览)
- 地中海船运公司通过SQL Server2005处理5TB的数 (0次浏览)
- 从SQL Server 4.2到SQL Server 2005 (0次浏览)



