二十二、PL/SQL编程
PL/SQL是Oracle的专用语言,它对标准的SQL语言进行了扩展。SQL语句可以嵌套在PL/SQL语言中,并结合处理语句。
22.1 PL/SQL程序结构
使用程序块的结构组织的代码。最简单的程序块是一种被称为“匿名块”的程序块,匿名块是指不会被Oracle存储以及重用的程序块。
PL/SQL程序通常包括3部分:Declare部分、exception部分、Begin和end部分。
Begin和end是PL/SQL的必须部分,一个程序块总是以begin开始,end语句结束。
Declare部分包含定义变量、常量和游标等类型的代码。
Begin与end之间可以嵌套begin…end及exception。
//打开服务器的输出 SQL> set serveroutput on; SQL> begin //开始 2 dbms_output.put_line('Hello World'); 3 end; 4 /
22.2 变量与常量
22.2.1 变量与常量的声明
变量名 类型(字符,日期,数字,布尔)[:=缺省值];
常量名 constant 类型(字符,日期,数字,布尔) [:=缺省值];
22.2.2变量与常量的区别
变量可以在任何部分进行赋值;
常量只可在declare中声明并且赋值。
注意:常量和变量都是在declare中声明
22.2.3 示例
declare pagesize constant number(2) :=10; begin dbms_output.put_line(pagesize); end; /
22.3 作用域
作用域是能够引用变量名称这样的标识符的程序块。
declare pagesize number(2):=10; //在整个中都有效 begin dbms_output.put_line(pagesize); declare pagesize number(2):=99; //只是在内容声明部分到end结束有效 begin dbms_output.put_line(pagesize); end; end; / //声明一个整型的变量 SQL> declare 2 age number(2); 3 begin 4 age:=90; 5 dbms_output.put_line(age); 6 end; 7 / //声明后直接赋值 SQL> declare 2 age number(2) :=90; 3 begin 4 dbms_output.put_line(age); 5 end; 6 / //捕获异常处理 SQL> declare 2 age number(2); 3 begin 4 age :='qwe'; 5 exception 6 when others then 7 dbms_output.put_line('赋值失败'); 8 end; 9 /
22.4 条件判断语句
PL/SQL与其他的编程语言一样,也都具有条件判断语句。在PL/SQL中常用的条件判断语句有IF和CASE语句。
22.4.1 IF语句
语法形式:
If(expression1)then
pl/sql_statement
Else
Pl/sql_statement;
End if;
If(expression1)then
pl/sql_statement
Else if(expression2)
Pl/sql_statement;
Else
Pl/sql_statement;
End if;
22.4.2 CASE语句
从oracle9i以后引入case语句。
语法形式:
Case <selector>
When <expression1> then pl/sql_statement1;
When <expression2> then pl/sql_statement2;
…
[else pl/sql_statement;]
End;
22.4.3 案例
SQL> declare score number(2) :=80; begin if score>70 then dbms_output.put_line('成绩合格'); end if; end; / SQL> declare score number(2) :=80; begin if score>90 then dbms_output.put_line('成绩合格'); else dbms_output.put_line('成绩不合格'); end if; end; / 成绩不合格 SQL> declare score number(2):=8; begin case score when 9 then dbms_output.put_line('成绩优秀'); when 8 then dbms_output.put_line('成绩亮'); end case; end; /