二十二、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;
/
PL/SQL编程入门
本文介绍了Oracle专有的PL/SQL编程语言,详细讲解了PL/SQL的基本结构、变量与常量的使用、作用域规则、条件判断语句等内容。通过多个实例演示了如何在PL/SQL中声明和使用变量与常量,以及如何实现基本的流程控制。
1688

被折叠的 条评论
为什么被折叠?



