oracle for循环
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle for循环相关的知识,希望对你有一定的参考价值。
打印三角形
参考技术A create or replace procedure test_yurui(
p_line in number
) is
v_line number;
begin
v_line:=p_line;
if(v_line<1) then
dbms_output.put_line('请输入>=1的整数');
end if;
for v in 1..p_line loop
for m in 1..p_line-v loop
dbms_output.put(' ');
end loop;
for n in 1..2*v-1 loop
dbms_output.put('*');
end loop;
dbms_output.put_line('');
end loop;
end test_yurui;
-----------------------效果如下---------------------
输入6
*
***
*****
*******
*********
***********本回答被提问者和网友采纳
Oracle for 循环
Oracle for in loop
循环的一些实例,以作学习和加强使用熟练度及场景应用.
一些技巧
for
语句后面的loop end loop
可以类比成c#/java
等编程语言for
语句后面的语句块符号(花括号{}
), 以便理解和使用.
一些实例
循环输出数值
-- 循环输出数值
begin
for i in 1 .. 100 loop
sys.dbms_output.put_line(i);
end loop;
end;
循环累加
-- 循环累加
declare
var_sum number := 0;
begin
for i in 1 .. 100 loop
var_sum := var_sum + i;
end loop;
sys.dbms_output.put_line(var_sum); -- 5050
end;
批量插入
-- 批量插入
begin
for i in 1 .. 100 loop
-- todo: insert into some_table(field1, field2, ..., fieldN) values(valie1, value2, ..., valueN);
sys.dbms_output.put_line('insert: ' || to_char(i));
end loop;
commit;
sys.dbms_output.put_line('多次insert,统一commit');
end;
批量更新
-- 批量更新
begin
for i in 1 .. 100 loop
-- todo: update some_table set fieldN = valueN where fieldN = valueN;
sys.dbms_output.put_line('update: ' || to_char(i));
end loop;
commit;
sys.dbms_output.put_line('多次update,统一commit');
end;
循环输出用户表信息
-- 查询你能管理的所有用户信息
select user_id, username, created from all_users;
-- 循环输出用户表信息
begin
for cur_row in (select user_id, username, created from all_users) loop
sys.dbms_output.put_line(cur_row.username);
end loop;
end;
-- 当循环对象是比较长串的SQL时,建议提取游标,方便后续查看和维护
循环输出用户表信息(游标提取)
-- 循环输出用户表信息(游标提取)
declare
-- 提取游标对象,方便单独维护SQL
cursor cursor_all_users is
select user_id, username, created from all_users;
-- 游标子项(更多的时候,表是动态表,所以这句声明也可以省略)
-- cursor_user all_users%rowtype;
begin
for cursor_user in cursor_all_users loop
dbms_output.put_line(cursor_user.username);
end loop;
end;
以上是关于oracle for循环的主要内容,如果未能解决你的问题,请参考以下文章