本随笔文章,由个人博客(鸟不拉屎)转移至博客园

发布时间: 2018 年 10 月 17 日

原地址:https://niaobulashi.com/archives/procedures_loop.html


存储过程LOOP疑问


今天在开发需求时,需要编写一个存储过程,实现数据的初始化功能。

发现遇到循环处理时,跳出循环的条件,Loop的处理

LOOP EXIT WHRN(P1 > P2);
...
END LOOP;

emmmmmm,因为之前没有怎么学习存储过程,只是看了一下存储过程的原理,就上手开发了(所谓了敏捷开发哈哈哈哈哈哈)

就引起我的疑问:是直接进入循环呢?还是先判断条件?

我上网查阅资料。。。好像没有查阅到额

不过看到有一个类型的,我贴出来

loop
v_sal := v_sal + 1;
dbms_output.put_line(v_sal);
exit when v_sal = 8000;
end loop

这个类比Java的do-while形式是一样的:先进入循环,满足条件了跳出循环

我就猜测

第一种也是这种类型的

于是我写了个测试例子,存储过程代码如下:

CREATE OR REPLACE PROCEDURE P_TEST(v_res OUT NUMBER,
v_errorCode OUT NVARCHAR2,
v_errorMsg OUT NVARCHAR2,
c_startDate IN NVARCHAR2) IS c_firstMonthDay NVARCHAR2(10); -- 所在月的第一天
c_firstClearDate NVARCHAR2(10); -- 第一次生成的披露日期
c_clearDate NVARCHAR2(10); -- 披露日期
c_N NUMBER(10):=1; -- 计算使用的倍数,从0开始 BEGIN
--================================================================================
-------------------------------【执行sql文】--------------------------------------
--================================================================================ /* 期间管理报告清算提示 Start */ -- 开启日志输出缓冲
DBMS_OUTPUT.ENABLE(buffer_size => null);
-- 获取当月的第一天和最后一天
SELECT to_char(last_day(to_date(substr(c_startDate,0,7)||'-01', 'yyyy-mm-dd')), 'yyyy-mm-dd') INTO c_firstMonthDay FROM dual;
--SELECT to_char(to_date(substr(c_startDate,0,7)||'-01', 'yyyy-mm-dd'), 'yyyy-mm-dd') INTO c_lastMonthDay FROM dual;
c_N := 1; -- 生成第一次提示日期
SELECT extract(YEAR FROM to_date(c_startDate, 'yyyy-mm-dd'))||'-'||'01'||'-'||'01'
INTO c_firstClearDate FROM dual;
c_clearDate := c_firstClearDate; -- 披露日期小于系统日期生成期间管理报告清算提示
LOOP EXIT WHEN (c_clearDate > c_startDate);
-- 直接生成收益分配提示
dbms_output.put_line('披露日期为:' || c_clearDate);
dbms_output.put_line('传入日期为:' || c_startDate);
dbms_output.put_line('进入循环,说明首次进入循环不做条件判断');
-- 用第一次提示日期计算下一次的提示日期
SELECT to_char(add_months(to_date(c_firstClearDate, 'yyyy-mm-dd'), c_N*12), 'yyyy-MM-')||'01' INTO c_clearDate FROM dual;
c_N := c_N + 1;
END LOOP; /* 期间管理报告清算提示 End */ --输出放回状态信息
v_res := 0;
v_errorCode := SQLCODE;
v_errorMsg := 'P_TEST' || ':' || TO_CHAR(SQLERRM); COMMIT; --异常处理
EXCEPTION
WHEN OTHERS THEN
ROLLBACK;
v_res := -1;
v_errorCode := SQLCODE;
v_errorMsg := 'P_TEST' || ':' || TO_CHAR(SQLERRM);
END P_TEST;

编写完成,通过测试代码:

begin
-- Call the procedure
p_test(v_res => :v_res,
v_errorcode => :v_errorcode,
v_errormsg => :v_errormsg,
c_startdate => '2018-10-17');
end;

可以通过debug模式一步一步观察代码执行,

我把存储过程执行结果的日志贴出来

通过打印的日志也可以得出结论:先进入循环,当满足条件,跳出结束循环~

就OK的啦~~~~

存储过程关于LOOP循环问题的更多相关文章

  1. 四、Oracle loop循环、while循环、for循环、if选择和case选择、更改读取数据、游标、触发器、存储过程

    数据库的设计(DataBase Design): 针对于用户特定的需求,然后我们创建出来一个最使用而且性能高的数据库! 数据库设计的步骤: 01.需求分析 02.概念结构设计 03.逻辑结构设计 04 ...

  2. MySQL中的while、repeat、loop循环

    循环一般在存储过程和存储函数中使用频繁,这里只给出最简单的示例 while delimiter $$ create procedure test_while() begin declare sum i ...

  3. Oracle之带参存储过程(存储过程中for循环调用存储过程)

    --带参存储过程create or replace procedure testdate(v in number) is i number; begin i:=v; insert into test_ ...

  4. oracle for loop循环以及游标循环

    1. for in loop形式 DECLARE    CURSOR c_sal IS SELECT employee_id, first_name || last_name ename, salar ...

  5. Oracle PL/SQL之LOOP循环控制语句

    在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...

  6. PL/SQL中LOOP循环控制语句

    在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...

  7. Oracle loop循环无法插入数据

    以下的测试基于scott用户下的emp表 首先用while循环进行测试,向emp表插入999条数据 declare i emp.empno; begin loop insert into emp(em ...

  8. MySql 存储过程 光标只循环一次

    [1]MqSql 存储过程 光标只循环一次 针对MySql存储过程,光标只循环一次就退出的场景,可能原因分析: (1)存储过程有问题(仔细检查语法.控制变量.条件等等) (2)保证存储过程正确.调用过 ...

  9. [转载]Oracle PL/SQL之LOOP循环控制语句

    在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...

随机推荐

  1. EF Core中外键关系的DeleteBehavior介绍(转自MSDN)

    Delete behaviors Delete behaviors are defined in the DeleteBehavior enumerator type and can be passe ...

  2. JAVA中的一些内置方法

    Math 函数: Math.E //自然常数e Math.abs(12.3); //返回该值的绝对值 Math.ceil(12.3); //向上取整 Math.floor(12.3); //向下取整 ...

  3. jdk1.8换成1.7

    电脑中装了jdk1.7,然后又装了1.8, 后来项目需要1.7,就把path环境变量中的java_home改成了1.7. 然后控制台输入java_version,后提示如下: Error: Regis ...

  4. MySQL学习之路(一)——初涉MySQL。

    MySQL学习之路(一) 1.1MySQL的概述 MySQL由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一个开源的关系型数据库管理系统. MySQL分为社区版和企业版. 1 ...

  5. CentOS7集成Apache和SVN

    本文主要介绍如何在CentOS7环境下集成Apache和SVN,完成后可以通过浏览器访问SVN仓库. 1.查看系统环境,关闭防火墙和SELinux. [root@Docker /]# systemct ...

  6. 如何提交代码到git仓库

    首先连接远程仓库 git remote add origin 仓库地址 然后拉取分支 git pull origin master 随后可查看本地增删改的文件 git status 增加本地的更改 g ...

  7. Redis全方位详解--磁盘持久化和容灾备份

    序言 在上一篇博客中,博客介绍了redis的数据类型使用场景和redis分布式锁的正确姿势.我们知道一旦Redis重启,存在redis里面的数据就会全部丢失.所以这篇博客中向大家介绍Redis的磁盘持 ...

  8. 《Java核心技术36讲》阅读笔记:Exception和Error有什么区别?

    1.Exception 和 Error有什么区别?运行时异常与一般异常有什么区别? Exception和Error都继承自java.lang.Throwable.在Java中只有Throwable的实 ...

  9. EntityFramework6.1自动生成复数名称数据表的问题

    遇到一个很奇怪的问题,两个程序部署在两个不同的机器上,一个是.net 4.6.1另外一个是.net 4.0的运行时,两个项目都引用了EntityFramework6.1.3.程序分别执行后,4.0环境 ...

  10. 20155231 实验二 Java面向对象程序设计

    20155231 java实验一 Java开发环境的熟悉 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim编辑器> 课程: 完成实验.撰写实验 ...