【Oracle存储过程】几种循环方式总结

 一.Oracle的循环

在所有的编程语言中,循环都是一个非常重要的语法,掌握循环,是程序员必不可少的能力。

  在Oracle中,常用的有四种循环,loop循环,while循环,for循环和goto循环,在本篇文章中,会向大家分别介绍这几种循环的语法和实例。

1. loop循环

  loop经常会与exit when关键字结合使用,具体语法如下:

loop    --开始循环的标志loop_body;   --要执行的语句           exit when 条件;  --退出循环的条件[loop_body;]   --要执行的语句end loop;    --结束循环的标志

循环输出数值:

-- 循环打印0-100之间的所有偶数,并求和
declare
var_num int:=0;
var_sum int:=0;
beginloopdbms_output.put_line(var_num);var_sum := var_sum + var_num;var_num := var_num + 2;exit when var_num >100;end loop;dbms_output.put_line(var_sum);
end;
2. while循环

  while循环和loop循环的语法非常相似,不过相较于loop循环,while循环多出了进入循环的条件,具体语法如下:

while 条件   --进入循环的条件loop         --循环开始的标志loop_body;      --要执行的循环语句[exit when 条件;]   --中途退出的条件end loop;
end;
declare
var_num int := 0;
beginwhile var_num <= 100loopdbms_output.put_line(var_num);var_num := var_num + 2;exit when var_num >100;end loop;
end;
3. for 循环

  for循环是四种循环中最为简单的一种,具体语法如下:

for 变量 in 小值..大值 looploop_body;[exit when 条件];
end loop;
-- 循环打印0-100之间的所有偶数
beginfor var_num in 0..100 loopif mod(var_num,2) = 0 thendbms_output.put_line(var_num);end if;end loop;
end;
4. goto循环

  goto的用法和其他三种循环都不一样,当使用goto时,可以无条件的跳到处于同一个PL/SQL块的任意执行语句处。具体使用方法如下:

-- 循环打印0-100之间的所有偶数,并求和
declare
var_num int := 0;
var_sum int := 0;
begin<<routine>>        --定义goto标签var_num := var_num + 1;                 --循环体,也就是需要执行的循环部分if mod(var_num,2) = 0 thendbms_output.put_line(var_num);var_sum := var_sum + var_num;end if;if var_num <= 100 then          --进入循环的条件goto routine;                        --返回上面的循环end if;dbms_output.put_line(var_sum);
end;

二.continue,retune,exit的使用

1. continue

  continue在英文中有继续的意思,在oracle中结合循环使用,则是跳过本次循环,继续下一次循环。

  利用cintinue关键字,可以轻松的做到数据的筛选,例如打印0-100之间的所有偶数:

declare
var_num int := -1;
beginloopvar_num := var_num +1;
# 当大于100时,会结束整个循环exit when var_num > 100;
# 当变量为奇数时,会跳过之后的执行语句,结束这次循环,从而进入下次循环 if mod(var_num,2) =1 thencontinue;end if;dbms_output.put_line(var_num);end loop;
end;   

continue不会跳出整个循环,它只是跳过不符合条件的本次循环从而开启新的循环,依旧处于循环阶段,直到所有数据全部循环完毕。

而exit则是在符合条件后,直接结束整个循环部分,转而去执行循环体外的其他内容。

2. return 

  在循环中使用exit和return时,两者的作用都是跳出整个循环,不过不同于exit ,return在跳出整个循环的同时,循环体外的其他内容也不会执行。

  下面给出几段代码,查看两者的不同:

beginfor var_num in 1..5 loopif var_num = 3 thenexit;--return;end if;dbms_output.put_line(var_num);  end loop;dbms_output.put_line('I love oracle!');
end; 

结果:

exit:
1
2
I love oracle!return:
1
2

可以看出相较于exit,return直接跳出了整个循环,同时还跳过了循环外的执行语句,直接结束了整段代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/746584.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录day20(2)二叉树:完全二叉树节点个数(leetcode222)

题目要求&#xff1a;求一个完全二叉树的节点个数 思路&#xff1a;首先完全二叉树可以用普通二叉树的方法来求&#xff0c;但是需要遍历所有的节点。 但是对于完全二叉树来说&#xff0c;只有最底层右侧的节点可能没满&#xff0c;其余每层节点都达到了最大值。所以我们可以…

智慧城管:街面秩序沿街商铺视频可视化AI智能监管方案

一、背景分析 随着城市化的加速和商业活动的日益繁荣&#xff0c;沿街商铺的管理面临着越来越多的挑战。沿街商户的乱堆乱放、占道经营、违章停车等违法行为&#xff0c;一直以来都是城市管理中的难题。这不仅存在交通安全隐患&#xff0c;也造成了市容秩序混乱&#xff0c;严…

MFMailComposeViewController 发送邮件

通过 MFMailComposeViewController 发送邮件,需预先登录邮箱账号的情况下; 具体实现与配置参数请参考如下: 首先,引入 MFMailComposeViewController 库 #import <MessageUI/MessageUI.h> 其次,实现相关 api 方法 if ([MFMailComposeViewController canSendMail]) {MFM…

整型变量的原子操作

什么是原子操作 原子操作&#xff08;Atomic Operation&#xff09;是指不可中断的操作&#xff0c;即在多线程环境下&#xff0c;当一个线程在执行原子操作时&#xff0c;不会被其他线程的调度和中断所影响。这种操作在多线程编程中尤为重要&#xff0c;因为它能保证操作的原…

从零开始搭建医保购药APP:技术选择与开发流程

医保购药APP作为一种创新的医疗服务工具&#xff0c;为用户提供了便捷的医保购药流程&#xff0c;同时也为医疗机构提供了更高效的管理和服务方式。今天小编将为大家讲解如何从零开始搭建一款医保购药APP&#xff0c;包括技术选择和开发流程。 一、技术选择 在搭建医保购药APP…

openssl3.2 - note - Decoders and Encoders with OpenSSL

文章目录 openssl3.2 - note - Decoders and Encoders with OpenSSL概述笔记编码器/解码器的调用链OSSL_STORE 编码器/解码器的名称和属性OSSL_FUNC_decoder_freectx_fnOSSL_FUNC_encoder_encode_fn官方文档END openssl3.2 - note - Decoders and Encoders with OpenSSL 概述 …

js-循环返回多条数据,每条数据文本超过三行进行展开与收起的实现

1.基本需求 返回多条数据&#xff0c;每条数据在一定宽度的盒子内&#xff0c;文本超过三行进行文本的展开与收起 2.实现逻辑 对于返回的每条数据添加属性expend&#xff1a;false来在循环中进行对于展开收起的判断。 动态计算盒子宽度随着分辨率的变化而变化的值boxWidth。获…

基于单片机的智能环境监测系统

摘 要 本设计主要由温湿度检测、烟雾检测电路、报警电路、显示电路和人体检测等模块组成。温湿度检测部分使用的是DHT11这种型号的温湿度传感器。DHT11是一种单总线型数字式温湿度传感器&#xff0c;它具有误差小、分辨率高、抗干扰能力强等特点。在烟雾检测电路模块当中&…

Nginx 隐藏版本号

只是隐藏 Nginx 版本号&#xff0c;只需在 Nginx 配置文件全局段添加 server_tokens off 然后重启 Nginx 服务 默认安装好了的 Nginx 服务 查看版本 现在修改配置 重启 Nginx 版本信息看不到了 我们下期见&#xff0c;拜拜&#xff01;

【MySQL】LEFT JOIN表时条件的位置对查询结果的影响

前言 我们知道,JOIN表的查询条件可以放在ON语句处,也可以放在 WHERE 语句处。 用 t2.status = 1 这条件举例: 方式1:放在 WHERE 语句处 SELECT t1.* FROM table1 t1 LEFT JOIN table2 AS t2 ON t2.k1 = t1.k2 WHERE t2.`status` = 1方式2:放在 ON 语句处 SELECT t1.*…

vsto判断workbook是否正在计算中

您可以使用 Workbook 对象的 CalculationState 属性来判断工作簿是否正在计算中。该属性返回一个 XlCalculation 枚举值&#xff0c;可以通过检查其是否等于 XlCalculation.xlCalculationManual 来确定工作簿是否处于手动计算模式&#xff0c;或者检查其是否等于 XlCalculation…

AIX7.2下安装python3

我们可以下载python3对应的AIX版本的安装包 http://www.aixtools.net/index.php/python3 直接执行 installp -d aixtools.python3.3.6.9.0.I -a all 安装完成后&#xff0c;默认安装位置在/opt/bin/python3

有趣之matlab-烟花

待整合1 2 3 动态 有趣编程之11 静态 逼真 3 .m文件路径下放back1.jpg back4.jpg…背景照片 点击screen 就会有小白点升起&#xff0c;爆炸 function yanhuamoban()clear all;%定义全局变量global ah ;%坐标轴句柄global styleNum ;%爆炸图案样式global multiColor; %多颜色变换…

Win11安装Plsql140报错2503

一、安装异常 二、解决办法 出现上述问题&#xff0c;主要是因为msi包安装的权限问题&#xff0c;使用管理员权限安装即解决 。cmd控制台以管理员身份打开WINR&#xff09;->(SHIFTCTRLRNTER)&#xff0c;进入到msi安装包目录下&#xff0c;以管理员身份安装即可&#xff1…

mysql数据库:使用 bash脚本 + 定时任务 自动备份数据

mysql数据库&#xff1a;使用 bash脚本 定时任务 自动备份数据 1、前言2、为什么需要自动化备份&#xff1f;3、编写备份脚本4、备份脚本授权5、添加定时任务6、重启 crond / 检查 crond 服务状态7、备份文件检查 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏…

Spring MVC共享域对象操作

1. 属性&#xff08;共享&#xff09;域介绍 在 JavaWeb 中&#xff0c;共享域指的是在 Servlet 中存储数据&#xff0c;以便在同一 Web 应用程序的多个组件中进行共享和访问。常见的共享域有四种&#xff1a;ServletContext、HttpSession、HttpServletRequest、PageContext。…

LeetCode28.找出字符串中第一个匹配项

28.找出字符串中第一个匹配项 给你两个字符串 haystack 和 needle &#xff0c;请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标&#xff08;下标从 0 开始&#xff09;。如果 needle 不是 haystack 的一部分&#xff0c;则返回 -1 。 示例 1&#xff1a; 输入…

C++中的C标准库、注释和条件编译

C中的C标准库、注释和条件编译 C标准库 C作为一种在C语言基础上发展起来的编程语言&#xff0c;保留了对C语言标准库的完整支持。这些C标准库提供了一系列的通用功能&#xff0c;如输入输出处理、字符串操作、数学计算等&#xff0c;允许C程序员利用已经熟悉的库来开展工作。…

虾皮Shopee根据ID取商品详情API

在构建电商平台的第三方应用或服务时&#xff0c;开发者经常需要通过编程方式获取商品的详细信息。对于虾皮Shopee平台来说&#xff0c;其提供的API接口使得这一需求得以实现。本文将详细介绍如何调用虾皮Shopee的API接口&#xff0c;根据商品ID获取其商品详情。 准备工作 在…

“优化消费环境 维护消费者权”荥阳市城关乡社工站开展3·15宣传志愿活动

又是一年“315”&#xff0c;为提高辖区群众消费维权意识&#xff0c;让他们可以学会运用政策法律知识维护自身合法权益&#xff0c;同时也为营造出辖区良好营商环境。2024年3月15日&#xff0c;在荥阳市民政局、荥阳市市场监督管理局、城关乡人民政府的支持下&#xff0c;城关…