(一) 条件分支语句
pl/sql中提供了三种条件分支语句if - then,if – then – else,if – then – elsif – then
1) 简单的条件判断 if– then - end if;
-- 输入一个人名,如果工资低于2000,就给员工工资增加10%。 create or replace procedure add_sal(name varchar2) is v_sal emp.sal%type; begin select sal into v_sal from emp where ename = name; if v_sal < 2000 then update emp set sal = sal + sal*0.1 where ename = name; end if; end;
2) 二重条件分支 if– then– else - end if;
-- 输入员工姓名,有补助则加100,没有则设为200; create or replace procedure add_comm(name varchar2) is v_comm emp.comm%type; begin select nvl(comm, 0) into v_comm from emp where ename = name; if v_comm <> 0 then update emp set comm = comm + 100 where ename = name; else update emp set comm = 200 where ename = name; end if; end;
3) 多重条件分支 if– then– elsif– then - else - end if;
注意:elsif, 不是elseif,也不是else if
-- 输入员工编号,如果是PRESIDENT工资加1000,MANAGER加500,其他加200 create or replace procedure addSalByEmpno(eno number) is v_job emp.job%type; v_val emp.sal%type; begin select job into v_job from emp where empno = eno; if (v_job = 'PRESIDENT') then -- 条件语句可以不使用() v_val := 1000; -- pl/sal中的赋值 := elsif v_job = 'MANAGER' then -- 切记: 是 elsif 而不是 elseif 也不是 else if v_val := 500; else v_val := 200; end if; update emp set sal = sal + v_val where empno = eno; end;
(二) 循环语句
1) 循环语句–loop
这种循环语句以loop开头,以end loop结尾,这种循环至少会被执行一次。
-- 现有users表如下: create table users(id number(4), name varchar2(20)); -- 输入用户名,并循环添加10个用户到users表中, 用户编号从1开始增加。 create or replace procedure add_users(name varchar2) is v_num number(4) := 1; begin loop insert into users values(v_num, name); exit when v_num = 10; v_num := v_num + 1; end loop; end;
2) 循环语句–while循环
基本循环至少要执行循环体一次,而对于while循环来说,只有条件为true时,才会执行循环体语句,while循环以while...loop
开始,以end loop结束。
-- 用while 循环重写add_users方法。 create or replace procedure add_users2(name varchar2) is v_num number(4) := 11; begin while v_num <= 20 loop insert into users values(v_num, name); v_num := v_num + 1; end loop; end;
3) 循环语句–for循环
-- 用for 循环重写add_users方法 create or replace procedure add_users3(name varchar2) is v_i number(4); begin for v_i in reverse 1..10 loop -- reverse可选的,倒序(10.9.8..) 如果不写为(1.2.3..) insert into users values(v_i, name); end loop; end;
(三) 顺序控制语句–goto,null
1) goto语句
goto语句用于跳转到特定符号去执行语句。goto语句会增加程序的复杂性,并使得应用程序可读性变差,所有不建议使用。用法goto lable; <<label>>
-- goto语句 set serveroutput on; declare i int := 1; begin loop dbms_output.put_line('输出 i = ' || i); if i = 5 then goto end_loop; end if; i := i + 1; end loop; <<end_loop>> dbms_output.put_line('循环结束'); end;
2) null语句
null语句不会执行任何操作,并且会直接将控制传递到下一条语句。使用null语句的主要好处是可以提高pl/sql的可读性。
-- null语句 declare v_sal emp.sal%type; v_ename emp.ename%type; begin select ename, sal into v_ename, v_sal from emp where empno = &no; if v_sal < 3000 then update emp set sal = sal + sal * 0.1 where ename = v_ename; else null; -- 什么也不做,为了提高可读性。 end if; end;
相关推荐
14oracle的PL/SQL编程-控制结构 PPT 14oracle的PL/SQL编程-控制结构 PPT
《Oracle PL/SQL程序设计(第5版)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何有效地使用它。...
《oracle pl/sql程序设计(第5版)》基于oracle数据库11g,从pl/sql编程、pl/sql程序结构、pl/sql程序数据、pl/sql中的sql、pl/sql应用构建、高级pl/sql主题6个方面详细系统地讨论了pl/sql以及如何有效地使用它。...
【实验目的】 1. 熟悉PL/SQL的数据类型和书写规则 2. 熟悉控制结构和游标的使用 3. 编写和运行函数、过程和触发器
学习pl/sql经典教程 重点: PL/SQL的控制结构 PL/SQL记录和表 过程与函数 异常处理
本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...
《Oracle PL/SQL程序设计(第5版)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何有效地使用它。...
本书是专门为Oracle应用开发人员提供的SQL和PL/SQL编程指南。通过学习本书,读者不仅可以掌握Oracle常用工具Oracle Universal Installer、Net Comfiguration Assistant、SQL Developer、SQL*Plus的作用及使用方法,...
控制结构 PL/SQL程序段中有三种程序结构:条件结构、循环结构和顺序结构。 1) 条件结构 与其它语言完全类似,语法结构如下: if condition thenstatement1elsestatement2end if ; 2) 循环结构 这一结构与其他...
本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...
《oracle pl/sql程序设计(第5版)》基于oracle数据库11g,从pl/sql编程、pl/sql程序结构、pl/sql程序数据、pl/sql中的sql、pl/sql应用构建、高级pl/sql主题6个方面详细系统地讨论了pl/sql以及如何有效地使用它。...
《oracle pl/sql程序设计(第5版)》基于oracle数据库11g,从pl/sql编程、pl/sql程序结构、pl/sql程序数据、pl/sql中的sql、pl/sql应用构建、高级pl/sql主题6个方面详细系统地讨论了pl/sql以及如何有效地使用它。...
本⽂⽬录: 1. PL/SQL 程序设计简介 2. PL/SQL块结构和组成元素 3. PL/SQL流程控制语句 4. 把游标说透 5. 异常错误处理 6. 把过程与函数说透 7. 程序包的创建与应⽤ 8. 把触发器说透
SQL与编程语言之间的不同...而PL/SQL是结构化的和过程化的结合体,而且最为重要的是,在用户执行多条SQL语句时,每条SQL语句都是逐一的发送给数据库,而PL/SQL可以一次性将多条SQL语句一起发送给数据库,减少网络流量
2) 扩展控制结构; 3) 扩展过程与函数; 4) 扩展对象类型与方法 ---- 第二章 PL/SQL程序结构 ---- 1. PL/SQL块 1) 申明部分, DECLARE (如果语句不需要声明任何变量,可以不写); 2) 执行部分, BEGIN ...
本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...
主要内容:PL/SQL 语言的基本特征、PL/SQL程序的结构、PL/SQL语言的控制结构、游标(cursor)编程、错误处理、存储过程和函数、创建包(Package)、触发器(Trigger)。
本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...
编写控制结构 7.1 条件分支语句 7.2 CASE语句 7.3 循环语句 7.4 顺序控制语句 7.5 习题 第8章 使用复合数据类型 8.1 PL/SQL记录 8.1.1 定义PL/SQL记录 8.1.2 使用PL/SQL...