游标、循环控制、异常处理

游标、循环控制、异常处理

ID:14891034

大小:43.50 KB

页数:14页

时间:2018-07-30

游标、循环控制、异常处理_第1页
游标、循环控制、异常处理_第2页
游标、循环控制、异常处理_第3页
游标、循环控制、异常处理_第4页
游标、循环控制、异常处理_第5页
资源描述:

《游标、循环控制、异常处理》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、游标、循环控制、异常处理--%type当表类型改变的时候,不需要手动修改PL/SQL块中调用的该类型--%type和%rowtype以及如何从数据库把数据取回来droptablestudentcreatetablestudent(idnumber,namevarchar2(20),agenumber(3,0))insertintostudent(id,name,age)values(1,'sx',25);begindeletefromstudent;forv_iin0..30loopinsertintostudent(id,name,age)values(v_i,'st'

2、

3、

4、v_i,10+v_i);endloop;end;--查找一个字段的变量declarev_namevarchar2(20);v_name2student.name%type;beginselectnameintov_name2fromstudentwhererownum=1;dbms_output.put_line(v_name2);end;--查找一个类型的变量,推荐用*declarev_studentstudent%rowtype;beginselect*intov_studentfromstudentwhererownum=1;dbms_output.put_line(v

5、_student.id

6、

7、''

8、

9、v_student.name

10、

11、''

12、

13、v_student.age);end;--if判断declarev_bboolean:=true;beginifv_bthendbms_output.put_line('ok');endif;end;--ifelsedeclarev_bboolean:=false;beginifv_bthendbms_output.put_line('ok');elsedbms_output.put_line('false');endif;end;--ifelsifelsedeclarev_namevarchar2(2

14、0):='sx';beginifv_name='0701'thendbms_output.put_line('0701');elsifv_name='sx'thendbms_output.put_line(v_name);--dbms_output.put_line('v_name');elsedbms_output.put_line('false');endif;end;--loop循环,注意退出exit是退出循环,不是退出整个代码块--Binary_Integer与Pls_Integer都是整型类型.Binary_Integer类型变量值计算是由Oracle来执行,不会出

15、现溢出,但是执行速度较慢,因为它是由Oracle模拟执--行。而Pls_Integer的执行是由硬件即直接由CPU来运算,因而会出现溢出,但其执行速度较前者快许多。declarev_ibinary_integer:=0;beginloopifv_i>10thenexit;endif;v_i:=v_i+1;--dbms_output.put(v_i);dbms_output.put_line(v_i);endloop;dbms_output.put_line('over');end;--更简单的写法declarev_ibinary_integer:=0;beginloopexi

16、twhenv_i>30;v_i:=v_i+1;dbms_output.put_line('Hello');endloop;dbms_output.put_line('over');end;--while循环declarev_ibinary_integer:=0;beginwhilev_i<30loopdbms_output.put_line('hello'+v_i);v_i:=v_i+1;endloop;dbms_output.put_line('over');end;--for循环,注意不需要声明变量beginforv_iin0..30loopdbms_output.put

17、_line('hello'

18、

19、v_i);endloop;dbms_output.put_line('over');end;--练习:新建student表(idinteger,--namevarchar2,--ageinteger--)用循环往student里插入30条记录--要求:id为0,1,2...--name为st0,st1,st2...--age为11,12,13...--2.查询出student表所有的记录,输出到终端--3.把students表中id是奇数的插入students1,把id是偶

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。