资源描述:
《游标、循环控制、异常处理》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
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是偶