频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

用SQLJ开发数据库

来源:yesky 作者:郑伟 出处:巧巧读书 2005-11-29 进入讨论组
上一页 1 2 3 4 5 6 下一页 
SQLJ代码与JDBC代码

  对于有输入参数的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;
...
PreparedStatement stmt = connection.prepareStatement(
"SELECT Ename, Sal " +
"INTO :vName, :vSalary " +
"FROM Emp " +
"WHERE Job = :vJob and HireDate = :vDate");

stmt.setString(1, vJob);
stmt.setTimestamp(2, vDate);

ResultSet rs = stmt.executeQuery();
rs.next();

vName = rs.getString(1);
vSalary = rs.getInt(2);

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 更多文章 更多内容请看数据库专栏数据库处理专题城域网专题专题,或进入讨论组讨论。
上一页 1 2 3 4 5 6 下一页 
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章