`
slbszq
  • 浏览: 264034 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

pl/sql编程中的控制结构

阅读更多

pl/sql编程中的控制结构

 () 条件分支语句

pl/sql中提供了三种条件分支语句if - thenif then elseif 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;

  

() 顺序控制语句gotonull

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 14oracle的PL/SQL编程-控制结构 PPT

    Oracle PL/SQL程序设计(第5版)(下册)第二部分

    《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程序设计 上 第五版(代码示例)

    《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编程

    【实验目的】 1. 熟悉PL/SQL的数据类型和书写规则 2. 熟悉控制结构和游标的使用 3. 编写和运行函数、过程和触发器

    oracle/pl/sql编程

    学习pl/sql经典教程 重点: PL/SQL的控制结构 PL/SQL记录和表 过程与函数 异常处理

    Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(二)

     本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...

    Oracle PL/SQL程序设计(第5版)(下册) 第一部分

    《Oracle PL/SQL程序设计(第5版)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何有效地使用它。...

    Oracle 11g SQL和PL SQL从入门到精通〖送源代码〗

    本书是专门为Oracle应用开发人员提供的SQL和PL/SQL编程指南。通过学习本书,读者不仅可以掌握Oracle常用工具Oracle Universal Installer、Net Comfiguration Assistant、SQL Developer、SQL*Plus的作用及使用方法,...

    PL/SQL Developer8.04官网程序_keygen_汉化

    控制结构 PL/SQL程序段中有三种程序结构:条件结构、循环结构和顺序结构。  1) 条件结构 与其它语言完全类似,语法结构如下: if condition thenstatement1elsestatement2end if ;  2) 循环结构 这一结构与其他...

    Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(一)

     本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...

    Oracle PL SQL程序设计 上 第五版part1

    《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程序设计 上 第五版part2

    《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编程详解.pdf

    本⽂⽬录: 1. PL/SQL 程序设计简介 2. PL/SQL块结构和组成元素 3. PL/SQL流程控制语句 4. 把游标说透 5. 异常错误处理 6. 把过程与函数说透 7. 程序包的创建与应⽤ 8. 把触发器说透

    oracle PL/SQL

    SQL与编程语言之间的不同...而PL/SQL是结构化的和过程化的结合体,而且最为重要的是,在用户执行多条SQL语句时,每条SQL语句都是逐一的发送给数据库,而PL/SQL可以一次性将多条SQL语句一起发送给数据库,减少网络流量

    PL/SQL 基础.doc

    2) 扩展控制结构; 3) 扩展过程与函数; 4) 扩展对象类型与方法 ---- 第二章 PL/SQL程序结构 ---- 1. PL/SQL块 1) 申明部分, DECLARE (如果语句不需要声明任何变量,可以不写); 2) 执行部分, BEGIN ...

    Oracle 11g SQL和PL SQL从入门到精通.part1

     本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...

    Oracle10g_PL_SQL_编程讲义

    主要内容:PL/SQL 语言的基本特征、PL/SQL程序的结构、PL/SQL语言的控制结构、游标(cursor)编程、错误处理、存储过程和函数、创建包(Package)、触发器(Trigger)。

    Oracle 11g SQL和PL SQL从入门到精通part2 pdf格式电子书 下载(二)

     本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...

    精通Oracle.10g.PLSQL编程

    编写控制结构 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...

Global site tag (gtag.js) - Google Analytics