欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > PPT文档下载
    分享到微信 分享到微博 分享到QQ空间

    第15章Oracle中的控制语句.ppt

    • 资源ID:388398       资源大小:62.50KB        全文页数:14页
    • 资源格式: PPT        下载积分:2000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要2000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    第15章Oracle中的控制语句.ppt

    1、第15章 Oracle中的控制语句,所有编程语言都离不开控制语句,Oracle也为PL/SQL编程提供了基本的控制语句。本章将针对最主要的两种控制语句:条件控制语句和循环语句进行讲解。本章内容包括: 条件语句:if else; 条件语句:case when; 循环语句:无条件循环; 循环语句:while循环; 循环语句:for循环。,15.1 Oracle中的条件语句,条件语句是指通过条件判断改变程序流程的语句。Oracle中提供了两种主要的条件语句:if else语句和case语句。,15.1.1 利用if else进行条件判断,if else语句是编程语言中最常见的条件控制语句。if关键字

    2、之后需要紧跟条件表达式,当该条件表达式返回为真时,将执行其后的语句,否则,将执行else之后的语句。 declare employee_num number; begin select count(*) into employee_num from t_employees where status = ACT;if employee_num0 then dbms_output.put_line(表T_EMPLOYEES中存在记录); else dbms_output.put_line(表T_EMPLOYEES中不存在记录); end if; end;,15.1.1 利用if else进行条件判

    3、断,declare employee_num number; begin select count(*) into employee_num from t_employees where status = ACT;if employee_num1 then dbms_output.put_line(表T_EMPLOYEES中存在多条有效记录); elsif employee_num = 1 then dbms_output.put_line(表T_EMPLOYEES中仅存在一条有效记录); else dbms_output.put_line(表T_EMPLOYEES中不存在记录); end i

    4、f; end; 注意:此处条件判断的写法,elsif不能写作else if。,15.1.2 利用case when进行分支判断,使用if else,当条件分支很多时,将不得不使用多个elsif分支。从Oracle 9i开始,可以利用另外一个条件判断的语句来实现多分支判断,这就是case when语句。 declare employee_num number; begin select count(*) into employee_num from t_employees where status = ACT;case when employee_num1 then dbms_output.pu

    5、t_line(表T_EMPLOYEES中存在多条有效记录); when employee_num = 1 then dbms_output.put_line(表T_EMPLOYEES中仅存在一条有效记录); else dbms_output.put_line(表T_EMPLOYEES中不存在记录); end case; end;注意与说明: 1case语句,在一种情况满足时,将不会继续匹配下面的条件,而是直接跳出判断语句。 2第二种case方式,只适用于表达式的值在有限,而且确定的范围之内进行匹配;而第一种方式则是使用逻辑判断。,15.2 Oracle中的循环语句,循环语句是除了条件语句之外,

    6、另一常用的控制语句。Oracle提供了三种主要的循环语句:无条件循环、while循环和for循环。,15.2.1 无条件循环,Oracle中的无条件循环是指,循环本身并不提供循环条件,而是由exit语句来控制何时跳出循环。 set serverout on; declare num number:=0; v_name varchar2(20); begin loop if num=5 then exit; end if; num := num + 1; select employee_name into v_name from t_employees where employee_id = n

    7、um; dbms_output.put_line(num | 号员工是: | v_name); end loop; end; 可以利用exit when来代替if判断。,15.2.2 while循环,while循环也是利用loop循环的形式。只是在loop循环之前添加条件判断,while即用来作为条件的标识。 declare num number:=0; v_name varchar2(20); begin while num 5 loop num := num + 1; select employee_name into v_name from t_employees where emplo

    8、yee_id = num;dbms_output.put_line(num | 号员工是: | v_name); end loop; end;,15.2.3 for循环,for循环适用于循环次数确定的情况。for循环会首先评估循环次数,然后针对每次循环都会将循环计数器累加1,直至达到循环次数。 declare v_name varchar2(20); begin for i in 1 5 loop select employee_name into v_name from t_employees where employee_id = i;dbms_output.put_line(i | 号员

    9、工是: | v_name); end loop; end;,15.3 本章实例,在Oracle中,同样可以使用嵌套循环,如【范例15-11】所示。 【范例15-11】该范例演示了Oracle中的嵌套循环。 通过本例可以看出,Oracle中的嵌套循环与其他语言中的嵌套循环用法一致。当然,开发者也可以使用其他任意两种循环形式进行嵌套循环。,15.3 本章实例,declare num number:=0;v_name varchar2(20); beginwhile num 5 loopnum := num + 1;select employee_name into v_name from t_em

    10、ployees where employee_id = num;dbms_output.put_line(num | 号员工是: | v_name);for i in 1num loopdbms_output.put(*);end loop;dbms_output.put_line();end loop; end;,15.4 本章小结,本章通过几个实例,介绍了如何使用循环语句。Oracle中所有循环的实质都是loop循环。只是根据是否在loop之前指定条件和条件的具体格式,分为无条件循环和while循环、for循环。值得注意的是,无条件循环内部对于exit的处理,一定要保证exit能够成功执行

    11、,否则,将会造成死循环。,15.5 习题,1试用case when语句改写以下语句。 if course = 0 then dbms_output.put_line(数学); elsif course = 1 then dbms_output.put_line(语文); elsif course = 2 then dbms_output.put_line(英语); else dbms_output.put_line(其他); end if;,15.5 习题,2试用无条件循环打印表students的雇员信息(包括雇员ID、雇员姓名)。 3利用while循环来完成上题的功能。 4利用for循环计算1100之间所有奇数的和。,


    注意事项

    本文(第15章Oracle中的控制语句.ppt)为本站会员(diecharacter305)主动上传,麦多课文档分享仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文档分享(点击联系客服),我们立即给予删除!




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
    备案/许可证编号:苏ICP备17064731号-1 

    收起
    展开