zoukankan      html  css  js  c++  java
  • oracle循环语句小结

    oracle循环语句小结
    2011-11-28 15:35

    主要有以下五种循环:Exit When、Loop、While、For(普通循环)、For(游标循环),下面举例一一说明(均为存储过程)。


    1、Exit When循环:
    create or replace procedure proc_test_exit_when is
    i number;
    begin
    i:=0;
    LOOP
    Exit When(i>5);
    Dbms_Output.put_line(i);
    i:=i+1;
    END LOOP;
    end proc_test_exit_when;
    ——————————————————–俺是分割线—————————————————————–

    2、Loop循环:
    create or replace procedure proc_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 proc_test_loop;
    ——————————————————–俺是分割线—————————————————————–

    3、While循环:
    create or replace procedure proc_test_while is
    i number;
    begin
    i:=0;
    while i<5 loop
    i:=i+1;
    dbms_output.put_line(i);
    end loop;
    end proc_test_while;
    ——————————————————–俺是分割线—————————————————————–

    4、For普通循环:
    create or replace procedure proc_test_for is
    i number;
    begin
    i:=0;
    for i in 1..5 loop
    dbms_output.put_line(i);
    end loop;
    end proc_test_for;
    ——————————————————–俺是分割线—————————————————————–

    5、For游标循环:
    create or replace procedure proc_test_cursor is
    userRow test%rowtype;
    cursor userRows is
    select * from test;
    begin
    for userRow in userRows loop
    dbms_output.put_line(userRow.id||’,'||userRow.Name||’,'||userRows%rowcount);
    end loop;
    end proc_test_cursor;
    ——————————————————–俺是分割线—————————————————————–

    上面所示为存储过程相应代码,你可以通过如下方式进行测试:

    进入pl/sql, 执行 文件->新建->程序窗口->空白,拷贝以上各段代码,到pl/sql空白窗口中,安F8执行编译。

    再 执行 文件->新建->命令窗口 进入命令窗口 执行一下  set serveroutput on 这句代码,然后,输入exec 相应存储过程,ok。

    第5中循环 要求新建一个名为test的表 字段 id、name,插入几条数据,进行测试即可。

    http://www.cnblogs.com/zsdentist/archive/2011/12/04/2276249.html 
  • 相关阅读:
    学习php 韩顺平 数据类型 三元运算,字符串运算类型运算
    学习php 韩顺平
    贪小便宜吃大亏关于汇泽平板和智能手表
    学习spring的第三天
    学习spring的第二天
    学习spring的第一天
    mybatis批量添加和删除
    关于mybatis的<selectKey>中的keyColumn
    mybatis+maven+父子多模块进行crud以及动态条件查询
    mybatis的插入数据后的主键获取
  • 原文地址:https://www.cnblogs.com/shined/p/2569493.html
Copyright © 2011-2022 走看看