重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
exit跳出循环,你是说要continue的那,这个似乎没有,可以用if else 来解决。
湘潭网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设等网站项目制作,到程序开发,运营维护。创新互联自2013年起到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联。
begin
for i in 1..10 loop
if i3 then
dbms_output.put_line(i);
if i=5 then
exit;
end if ;
end if;
end loop;
end;
loop循环有3种
第一种直接loop 用exit when 退出
第二种是for loop 他用 for i in ... loop
第三种是while loop
exit跳出循环。SQLSERVER用BREAK
if 跳出循环的条件 then
exit;
end if;
或者
exit when 条件(一定是一个返回true或者false的判断条件)
select * from v$access a where object like '存储过程名%' --存储过程名为大写字母
select * from v$session where sid=74 --74为上一个查询得到的SID值,可能是多个,这里找到他们对应的serial#值
alter system kill session '74,118' --参数为'sid,serial#',用于停止这个回话,同时也终止了存储过程
BEGIN
dbms_lock.sleep(300);
FOR I IN 1..100 LOOP
dbms_lock.sleep(120);
INSERT INTO CONN_TEST(CODE_DESC) VALUES (I);
//在这里去读一个表里面的值,你可以通过改变此值强制退出循环
select stopflg into v_stopflag from testtabble;
if v_stopflag =1 then exit; end if;
END LOOP;
END;
如果表中存在数据的话,没差别。
但是如果表中没有数据的话,第一个不会打印任何结果,第二个会打印一个【'学号:'',姓名:''】
***补充:****
更正:
如果表中存在数据的话,第二个的最后一条记录重复出现一次。
但是如果表中没有数据的话,第一个不会打印任何结果,第二个会打印一个【'学号:'',姓名:''】
*************
@@@@补充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到底后肯定会先打印再停止循环,而打印的结果就是上一次残留的记录,就是最后一条记录。
########################
--
以上,希望对你有所帮助。