如何理解oracle循环 oracle sql循环

Oracle中游标与循环的问题

如果表中存在数据的话,没差别。

创新互联建站-专业网站定制、快速模板网站建设、高性价比榆社网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式榆社网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖榆社地区。费用合理售后完善,十载实体公司更值得信赖。

但是如果表中没有数据的话,第一个不会打印任何结果,第二个会打印一个【'学号:'',姓名:''】

***补充:****

更正:

如果表中存在数据的话,第二个的最后一条记录重复出现一次。

但是如果表中没有数据的话,第一个不会打印任何结果,第二个会打印一个【'学号:'',姓名:''】

*************

@@@@补充2:@@@@@

出现重复记录的原因(以两条数据为例):

第一种情况:

1、循环外先fetch一条,发现不是mycur%notfound,进入循环体打印第一条记录。

2、再fetch一条,发现不是mycur%notfound,继续循环打印第二条记录。

3、再fetch一条,发现是mycur%notfound,停止循环。

第二种情况:

1、直接进入循环fetch一条,发现不是mycur%notfound,打印第一条记录。

2、再循环fetch一条,发现不是mycur%notfound,打印第二条记录。

3、再循环fetch一条,发现是mycur%notfound,但程序顺序执行又执行了一遍打印,这个时候因为没有记录产生,变量中存放的就是上一条记录,所以重复打印第二条记录后,退出循环。

@@@@@@@@@@@@@@@@@@@@@@@@@

#######补充3:###########

不要管循环几次(我举例子是为了方便理解,既然理解不了就不要想了)。你想:程序是顺序执行的,第一种情况循环里面的fetch后直接跟的是循环停止条件,这样fetch到底后直接跳出循环。第二种情况fetch后跟的是打印,这样fetch到底后肯定会先打印再停止循环,而打印的结果就是上一次残留的记录,就是最后一条记录。

########################

--

以上,希望对你有所帮助。

刚学oracle 请问下循环的原理和作用

作用相当于把ticketbonus表所有记录的info5 的值都修改为seq_ticketbonus.nextval(已创建的序列);

首先看外层for i in (select * from ticketbonus) loop,这是对ticketbonus表进行循环,将每一列查询结果赋予变量i,然后把i.主键当作条件值更新ticketbonus 表

oracle存储过程循环怎么写

Oracle中有三种循环(For、While、Loop):

1、loop循环:

create or replace procedure pro_test_loop is

i number;

begin

i:=0;

loop

i:=i+1;

dbms_output.put_line(i);

if i5 then

exit;

end if;

end loop;

end pro_test_loop;

2、while循环:

create or replace procedure pro_test_loop  is

i number;

begin

i:=0;

while i5 loop

i:=i+1;

dbms_output.put_line(i);

end loop;

end pro_test_loop;

3、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;

4、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;


本文名称:如何理解oracle循环 oracle sql循环
网页网址:http://myzitong.com/article/hjoghd.html