db2普通循环结构

while循环

  1. while 条件
  2. do
  3. 循环体
  4. end while;

LOOP循环

  1. SET V_INDEX = 0;
  2. AUTHLOOP:
  3. LOOP
  4. V_INDEXV_INDEX = V_INDEX + 1;
  5. IF V_INDEX >=100 THEN
  6. LEAVE AUTHLOOP;--相当于break
  7. END IF;
  8. ....
  9. IF 条件 THEN
  10. ITERATE AUTHLOOP;-- 相当于continue
  11. END IF;
  12. SET V_INDEXV_INDEX = V_INDEX + 1;
  13. END LOOP;

REPEAT循环

  1. REPEAT
  2. SQL statements;
  3. UNTIL condition – 退出条件
  4. END REPEAT

FOR 循环

  1. FOR loop_name AS
  2. SELECT … FROM
  3. DO
  4. SQL statements;
  5. END FOR;

循环实例:

loop循环:
create or replace procedure pro_test_loop is
i number;
begin
i:=0;
loop
  i:=i+1;
  dbms_output.put_line(i);
  if i>5 then
    exit;
  end if;
end loop;
end pro_test_loop;

while循环:
create or replace procedure pro_test_while is
i number;
begin
i:=0;
while i<5 loop
  i:=i+1;
  dbms_output.put_line(i);
end loop;
end pro_test_while;

for循环1:
create or replace procedure pro_test_for is
i number;
begin
i:=0;
for i in 1..5 loop
  dbms_output.put_line(i);
end loop;
end pro_test_for;

for循环2:
create or replace procedure pro_test_cursor is
userRow t_user%rowtype;
cursor userRows is
select * from t_user;
begin
for userRow in userRows loop
    dbms_output.put_line(userRow.Id||','||userRow.Name||','||userRows%rowcount);
end loop;
end pro_test_cursor;

游标循环使用:

1.利用得到的游标在存储过程中循环:

DECLARE CUR_FEESET CURSOR WITH RETURN TO CALLER FOR (

SELECT

--

FROM 表

WHERE 条件

);

OPEN CUR_FEESET;--得到游标

--得到游标记录数

SELECT

count(CIF_CSTNO)

into v_count

FROM CB_CSTINF A ,CB_CSTBSNINF B

WHERE A.CIF_STT<>'3' AND A.CIF_CSTNO = B.CBI_CSTNO ; --

FETCH CUR_FEESET INTO V_CSTNO,V_FEECODE,V_CSTLEVEL,V_FEEMODE;--

WHILE V_COUNT>0 DO

     ……..

FETCH CUR_FEESET INTO V_CSTNO,V_FEECODE,V_CSTLEVEL,V_FEEMODE;--

END WHILE; --

2.另一种db2标准循环格式(leave、iterate 用法):

SET V_COUNT = LENGTH(V_VALIDAUTHCOMBOS);--

SET V_INDEX = 0;--

AUTHLOOP:

LOOP

IF V_INDEX >= V_COUNT THEN

LEAVE AUTHLOOP;--相当于break

END IF;--

....

SET V_INDEX = V_INDEX + 1;--

.......

IF 条件 THEN

ITERATE AUTHLOOP;-- 相当于continue

END IF;--

END LOOP;--

3.截取字符串的循环(设V_TEMP=‘CB1001|CB1002|CB1003|’):

SET V_LENGTH = LENGTH(V_TEMP);

WHILE V_LENGTH>0 DO

SET V_POS = POSSTR(V_TEMP,'|');

SET V_CURRENT_BSN = SUBSTR( V_TEMP, 1, V_POS-1 );

SET V_TEMP = SUBSTR( V_TEMP, V_POS+1 );

SET V_LENGTH = LENGTH(V_TEMP);

--最后一个字段,不再截取

SET V_BSNTYPE = V_CURRENT_BSN;

END WHILE;

4.游标循环(不用open 游标):

DROP PROCEDURE TESTFOR;

CREATE PROCEDURE TESTFOR()

LANGUAGE SQL

BEGIN

DECLARE V_TEMP1 VARCHAR(2);

DECLARE V_TEMP2 VARCHAR(70);

FOR V1 AS CURSOR1 CURSOR FOR

SELECT STUDENT_ID AS TEMP1,STUDENT_NAME AS TEMP2 FROM STUDENT

DO

DELETE FROM STUDENT WHERE STUDENT_ID = TEMP1;

SET V_TEMP1 = TEMP1;

SET V_TEMP2 = TEMP2;

END FOR;

COMMIT;

END;

db2循环的更多相关文章

  1. DB2中循环日期跑数据

    1.数据库版本: 2.具体实现方式: ),)) /*************************************************************************** ...

  2. DB2(Procedure)存储过程遍历循环!

    有时候一些复杂的业务逻辑将要通过存储过程的循环语句进行处理;以下列出2种DB2存储过程的循环语句,方便以后的查看并使用! 推荐第一种方式的使用,最大的优点就是比较直观;在需要操作很多字段的情况下,不需 ...

  3. 你搞懂 ORACLE、 SQLSERVER、MYSQL与DB2的区别了吗

    ORACLE. SQLSERVER.MYSQL与DB2的区别--平台性:    Oracle.MYSQL与DB2可在所有主流平台上运行:    SQL Server只能在Windows下运行: --安 ...

  4. DB2错误码信息

    00 完全成功完成 表 3  01 警告 表 4  02 无数据 表 5  07 动态 SQL 错误 表 6  08 连接异常 表 7  09 触发操作异常 表 8  0A 功能部件不受支持 表 9  ...

  5. db2基础

    DB2知识文档 一.db2 基础 基本语法 注释:"--"(两个减号) 字符串连接:"||" 如set msg='aaaa'||'bbbb',则msg为'aaa ...

  6. db2 游标使用

    游标一般用来迭代结果集中的行 为了在一个过程中处理一个游标的结果,需要做以下事情: 在存储过程块的开头部分 DECLARE 游标. 打开该游标. 将游标的结果取出到之前已声明的本地变量中(隐式游标处理 ...

  7. db2存储过程

    一. 使用存储过程的好处 1. 减少客户机与服务器之间的网络使用率,以及数据库锁定保持的时间 应用程序通常在执行每个SQL语句都要跨网络两次,存储过程可以将SQL语句集中在一起, 从而使得对于每一组S ...

  8. DB2 表空间和缓冲池

    简介 对于刚涉足 DB2 领域的 DBA 或未来的 DBA 而言,新数据库的设计和性能选择可能会很令人困惑.在本文中,我们将讨论 DBA 要做出重要选择的两个方面:表空间和缓冲池.表空间和缓冲池的设计 ...

  9. DB2存储过程语法规则

    如何声明一个存储过程CREATE PROCEDURE 存储过程名(IN 输入变量名 输入变量类型,OUT 输出变量名 输出变量类型)紧跟其后的是存储过程属性列表            常用的有:LAN ...

随机推荐

  1. 为select 设置样式

    问题: 在为表单添加下拉菜单时,有时候对菜单的样式没有特别的要求,就是需要修改下select元素的宽度和高度,但众所周知select元素的样式很难修改: select在各个浏览器,字体大小为14px时 ...

  2. js对Cookie的读写操作

    //读Cookie function getCookie(objName) {//获取指定名称的cookie的值 var arrStr = document.cookie.split("; ...

  3. trap命令

    一. [root@OEL6-38 arun]# vim yy.sh --------------------- 参考: http://blog.csdn.net/holandstone/article ...

  4. amazeui折叠面板智能化展开

    2016年12月12日 21:05:18 星期一 场景: 我拿这个组件用作管理后台的侧边栏 效果: 根据当前访问的url不同, 展开不同的面板 amazeui折叠面板 js代码: <script ...

  5. Python之路,Day5 - Python基础5

    本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 一.列表生成器 , 1, 2, 3, 4, 5, 6, 7, 8, 9 ...

  6. display:none与visible:hidden的区别 slideDown与

    display:none与visible:hidden的区别 display:none和visible:hidden都能把网页上某个元素隐藏起来,但两者有区别: display:none ---不为被 ...

  7. centos系统/etc/sysconfig/目录下无iptables文件

    原因一般是没有配置过防火墙,在安装linux系统时也已经禁掉了防火墙 随便写一条iptables命令配置个防火墙规则:如: iptables -P OUTPUT ACCEPT 然后用命令:servic ...

  8. JSP复习整理(二)基本语法

    最基础的整理.. 一.语句声明 <%@ page language="java" contentType="text/html; charset=UTF-8&quo ...

  9. Mac OS X 上安装 ASP.NET 5

    在Mac OS X Yosemite 10.10.3 中搭建第一个 ASP.NET 5 Web 项目 终于有时间在 Mac 上安装一下 ASP.NET 5,网上有许多教程,但是多数的时间比较早了,版本 ...

  10. MySQL--InnoDB索引原理详解

    1 各种树形结构 本来不打算从二叉搜索树开始,因为网上已经有太多相关文章,但是考虑到清晰的图示对理解问题有很大帮助,也为了保证文章完整性,最后还是加上了这部分. 先看看几种树形结构: 1 搜索二叉树: ...