Oracle和SQLServer的语法区别(5)

2019-08-20 19:54

VDEGREE_PROGRAM CHAR(1); @VDEGREE_PROGRAM CHAR(1), VDEGREE_PROGRAM_NAME @VDEGREE_PROGRAM_NAME VARCHAR2(20); VARCHAR(20) BEGIN SELECT @VDEGREE_PROGRAM = 'U' VDEGREE_PROGRAM := 'U'; SELECT @VDEGREE_PROGRAM_ IF VDEGREE_PROGRAM = 'U' THEN NAME = CASE @VDEGREE_PROGRAM VDEGREE_PROGRAM_NAME := WHEN 'U' THEN 'Undergraduate' 'Undergraduate'; WHEN 'M' THEN 'Masters' ELSIF VDEGREE_PROGRAM = 'M' WHEN 'P' THEN 'PhD'. THEN VDEGREE_PROGRAM_ ELSE 'Unknown' NAME := 'Masters'; END ELSIF VDEGREE_PROGRAM = 'P' THEN VDEGREE_PROGRAM_ NAME := 'PhD'; ELSE VDEGREE_PROGRAM_ NAME := 'Unknown'; END IF; END; 重复的语句执行(循环)

Oracle PL/SQL 提供了无条件的 LOOP 和 FOR LOOP。而 Transact-SQL 则提供了 WHILE 循环和 GOTO 语句,来达到循环的目的。 WHILE Boolean_expression

{sql_statement | statement_block} [BREAK] [CONTINUE]

对于一个或多个语句的重复执行,WHILE 循环测试一个布尔表达式。只要给定的表达式求值为 TRUE,语句就会重复执行。如果要执行多个语句,它们必须放在一个 BEGINUEND 块中。

Oracle DECLARE COUNTER NUMBER; BEGIN COUNTER := 0 WHILE (COUNTER <5) LOOP COUNTER := COUNTER + 1; END LOOP; END; Microsoft SQL Server DECLARE @COUNTER NUMERIC SELECT@COUNTER = 1 WHILE (@COUNTER <5) BEGIN SELECT @COUNTER = @COUNTER +1 END 可以使用 BREAK 和 CONTINUE 关键字,从循环的内部控制语句的执行。BREAK 关键字导致从 WHILE 循环中无条件退出,CONTINUE 关键字使 WHILE 循环跳过后面的语句,并重新开始循环。BREAK 关键字和 Oracle PL/SQL EXIT 关键字等同。Oracle 没有 CONTINUE 的对等关键字。

GOTO 语句

Oracle 和 Microsoft SQL Server 均有 GOTO 语句,但是语法不同。遇到 GOTO 语句,Transact-SQL 批处理执行就会跳到标号处。GOTO 语句和标号之间的语句不执行。

Oracle GOTO label; <

Transact-SQL PRINT 语句和 PL/SQL RDBMS_OUTPUT.put_line 过程所执行的操作相同。它用于打印用户指定的消息。

PRINT 语句的消息限度为 8,000 个字符。使用 char 或 varchar 数据类型定义的变量可以嵌入打印语句中。如果使用了任何其它数据类型,必须使用 CONVERT 或 CAST 函数。可以打印局部变量、全局变量和文本。可用单引号和双引号将文本括上。

从存储过程返回

Microsoft SQL Server 和 Oracle 均有 RETURN 语句。使用 RETURN 语句,程序可从查询或过程无条件退出。RETURN 是一条可立即执行的完整语句,并可在任何时候用于从过程、批处理或语句块中退出。RETURN 后面的语句均不执行。

Oracle RETURN expression: Microsoft SQL Server RETURN [integer_expression] 提出程序错误

Transact-SQL RAISERROR 语句返回一个用户定义的错误信息,并设定一个系统标志,来记录已发生了一个错误。它和 PL/SQL raise_application_error 异常错误处理程序的功能相似。 RAISERROR 语句允许客户从 sysmessages 表检索一个条目,或使用用户定义的严重性和状态信息动态地创建一条消息。定义后,此消息作为服务器错误信息返回给客户。

RAISERROR ({msg_id | msg_str}, severity, state [, argument1 [, argument2]]) [WITH options]

转换 PL/SQL 程序时,可能不需要使用 RAISERROR 语句。在下面的代码示例中,PL/SQL 程序使用 raise_application_error 异常错误处理程序,而 Transact-SQL 程序什么也不使用。加入 raise_application_error 异常错误处理程序,可避免 PL/SQL 程序返回二义性的 unhandled exception 错误信息。相反,当发生意外问题时,它总是返回 Oracle 错误信息 (SQLERRM)。

当 Transact-SQL 程序失败时,它总是给客户程序返回详细的错误信息。因此,除非需要进行专门错误处理,否则,并不总是需要 RAISERROR 语句。

Oracle CREATE OR REPLACE FUNCTION DEPT_ADMIN.DELETE_DEPT (VDEPT IN VARCHAR2) RETURN NUMBER AS BEGIN DELETE FROM DEPT_ADMIN.DEPT WHERE DEPT = VDEPT; RETURN(SQL%ROWCOUNT); EXCEPTION WHEN OTHER THEN RAISE_APPLICATION_ERROR (-20001,SQLERRM); END DELETE_DEPT; / Microsoft SQL Server CREATE PROCEDURE DEPT_ADMIN.DELETE_DEPT @VDEPT VARCHAR(4) AS DELETE FROM DEPT_DB.DBO.DEPT WHERE DEPT = @VDEPT RETURN @@ROWCOUNT GO 游标的实现

不管从数据库中请求行数的多少,Oracle 始终要求游标和 SELECT 语句一起使用。在 Microsoft SQL Server 中,未包含在游标内的 SELECT 语句把行作为默认结果集,返回给客户。这是一种将数据返回给客户程序的有效方法。

SQL Server 给游标函数提供了两个接口。当在 Transact-SQL 批处理或存储过程时使用游标时,SQL 语句可用来声明、打开游标和从游标以及定位更新和删除中提取。当使用来自 DB-Library、ODBC 或 OLE DB 的游标时,SQL Server 客户机库透明地调用内置的服务器函数,以更有效地处理游标。

当从 Oracle 导入 PL/SQL 过程时,首先确定游标是否需要执行和 Transact-SQL 中相同的功能。如果游标只给客户程序返回一组行,则使用 Transact-SQL 中无游标的 SELECT 语句,返回一个默认的结果集。如果使用游标向局部过程变量每次加载一行数据,则必须使用 Transact-SQL 中的游标。

下表给出了游标的使用语法。

操作 Microsoft SQL Server DECLARE cursor_name CURSOR [LOCAL | GLOBAL] [FORWARD_ONLY | SCROLL] [STATIC | KEYSET | CURSOR cursor_name DYNAMIC | 声明游标 [(cursor_parameter(s))] FAST_FORWARD] IS select_statement; [READ_ONLY | SCROLL_LOCKS | OPTIMISTIC] [TYPE_WARNING] FOR select_statement [FOR UPDATE [OF column_name [,Un]]] OPEN cursor_name 打开游标 OPEN cursor_name [(cursor_parameter(s))]; FETCH [[NEXT | PRIOR | FIRST | LAST | ABSOLUTE {n | @nvar} FETCH cursor_name INTO 从游标中提取 | RELATIVE {n | variable(s) @nvar}] FROM] cursor_name [INTO @variable(s)] UPDATE table_name UPDATE table_name SET statement(s)U SET statement(s)U 更新提取的行 WHERE CURRENT OF WHERE CURRENT OF cursor_name; cursor_name DELETE FROM DELETE FROM table_name table_name 删除提取的行 WHERE CURRENT OF WHERE CURRENT OF cursor_name; cursor_name 关闭游标 CLOSE cursor_name; CLOSE cursor_name DEALLOCATE 删除游标数据结构 暂缺 cursor_name 尽管 Transact-SQL DECLARE CURSOR 语句不支持使用游标参数,但它的确支持局部变量。当游标打开时,这些局部变量的值可在游标中使用。Microsoft SQL Server 在其 DECLARE CURSOR 语句中提供了许多额外的功能。

Oracle INSENSITIVE 选项用于定义游标,使之创建一个要使用的数据的临时副本。对游标的所有请求均由此临时表应答。因此,对基表的修改不会反映在对该游标提取所返回的数据中。这种类型游标访问的数据不能被修改。

应用程序可以请求一种游标类型,然后执行一条不被所请求类型服务器游标支持的

Transact-SQL 语句。SQL Server 就会返回一个错误,指出游标类型已经更改;或者如给定了一组要素,SQL Server 就会隐式转换游标。有关使 SQL Server 7.0 隐式地将游标从一种类型转换到另一种类型的完整要素列表,请参见 SQL Server Books Online。

除向前提取外,SCROLL 选项还允许向后、绝对和相对提取。滚动游标使用键集游标模型,在该模型中,任何用户对基表的已提交删除和更新都会反映在以后的提取中。仅当没有使用 INSENSITIVE 选项来声明该游标时,才成立。

如果选定了 READ ONLY 选项,则禁止对游标中的任何行进行更新。该选项将改写对游标更新的默认功能。

UPDATE [OF column_list] 语句用于定义游标中可更新的列。如果给出了 [OF column_list],则只有列出的列允许修改。如果没有给出列表,所有的列均可更新,除非游标已定义为 READ ONLY。

注意到,SQL Server 游标的名称作用域就是连接本身这一点,是很重要的。这和局部变量的名称作用域不同。在同一用户连接上,在第一个游标释放之前,不能声明与现有游标名称相同的第二个游标。

与 PL/SQL 不同,在一个游标打开时,Transact-SQL 不支持向该游标传递参数。当 Transact-SQL 游标打开时,结果集成员身份和次序是固定的。对于其他用户已提交的对基表的更新和删除,均会反映在所有未使用 INSENSITIVE 选项定义的游标提取中。对于 INSENSITIVE 游标,还会生成一个临时表。

Oracle 游标只能向前移动--不能向后或相对滚动。SQL Server 可以使用下表所示的提取选项,向前和向后滚动。只有当游标使用 SCROLL 选项声明时,这些提取选项才可以使用。

滚动选项 NEXT PRIOR FIRST LAST ABSOLUTE n RELATIVE n 说明 如果是对游标的提取,返回结果集的第一行,如果不是,在结果集中移动游标一行。NEXT 是在结果集中移动所使用的主要方法。NEXT 是默认的游标提取。 在结果集中,返回上一行。 把游标移动到结果集的第一行,并返回第一行。 把游标移动到结果集的最后一行,并返回最后一行。 返回结果集中的第 n 行。如果 n 是负值,则返回的行是从结果集最后一行向回数的第 n 行。 返回当前提取行后的第 n 行。如果 n 是负值,返回的行是从游标的相对位置向回数的第 n 行。


Oracle和SQLServer的语法区别(5).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:JSP学期授课计划

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: