`
孔雀王子
  • 浏览: 40934 次
  • 性别: Icon_minigender_1
  • 来自: 河北
文章分类
社区版块
存档分类
最新评论

Oracle数据库管理、应用与开发(十六)

阅读更多

二十二、PL/SQL编程

PL/SQLOracle的专用语言,它对标准的SQL语言进行了扩展。SQL语句可以嵌套在PL/SQL语言中,并结合处理语句。

22.1 PL/SQL程序结构

使用程序块的结构组织的代码。最简单的程序块是一种被称为“匿名块”的程序块,匿名块是指不会被Oracle存储以及重用的程序块。

PL/SQL程序通常包括3部分:Declare部分、exception部分、Beginend部分。

BeginendPL/SQL的必须部分,一个程序块总是以begin开始,end语句结束。

Declare部分包含定义变量、常量和游标等类型的代码。

Beginend之间可以嵌套begin…endexception

//打开服务器的输出
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中常用的条件判断语句有IFCASE语句。

             22.4.1 IF语句

语法形式:

                        Ifexpression1then

pl/sql_statement

                        Else

                           Pl/sql_statement;

                        End if;

                           

Ifexpression1then

pl/sql_statement

                        Else ifexpression2

                           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;
/

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics