欢迎来到天天文库
浏览记录
ID:39774005
大小:89.00 KB
页数:9页
时间:2019-07-11
《Oracle习题集锦》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、Oracle作业题一.创建一个简单的PL/SQL程序块使用不同的程序块组件工作使用编程结构编写PL/SQL程序块处理PL/SQL程序块中的错误1.编写一个程序块,从emp表中显示名为“SMITH”的雇员的薪水和职位。declarev_empemp%rowtype;beginselect*intov_empfromempwhereename='SMITH';dbms_output.put_line(v_emp.job
2、
3、'--'
4、
5、v_emp.sal);end;2.编写一个程序块,接受用户输入一个部门号,从dept表中显示该部门的名称与所在位置。declare
6、v_deptdept%rowtype;beginselect*intov_deptfromdeptwheredeptno=&部门号;dbms_output.put_line(v_dept.dname
7、
8、'--'
9、
10、v_dept.loc);end;3.编写一个程序块,利用%type属性,接受一个雇员号,从emp表中显示该雇员的整体薪水(即,薪水加佣金)。declarev_salemp.sal%type;beginselectsal+commintov_salfromempwhereempno=&雇员号;dbms_output.put_line(v_sal);e
11、nd;4.编写一个程序块,利用%rowtype属性,接受一个雇员号,从emp表中显示该雇员的整体薪水(即,薪水加佣金)。declarev_empemp%rowtype;beginselect*intov_empfromempwhereempno=&雇员号;dbms_output.put_line(v_emp.sal+v_emp.comm);end;5.某公司要根据雇员的职位来加薪,公司决定按下列加薪结构处理:DesignationRaise-----------------------Clerk500Salesman1000Analyst1500Otherw
12、ise2000编写一个程序块,接受一个雇员名,从emp表中实现上述加薪处理。declarev_empemp%rowtype;beginselect*intov_empfromempwhereename='&name';ifv_emp.job='CLERK'thenupdateempsetsal=sal+500whereempno=v_emp.empno;elsifv_emp.job='SALESMAN'thenupdateempsetsal=sal+1000whereempno=v_emp.empno;elsifv_emp.job='ANALYST'then
13、updateempsetsal=sal+1500whereempno=v_emp.empno;elseupdateempsetsal=sal+2000whereempno=v_emp.empno;endif;commit;end;6.编写一个程序块,将emp表中雇员名全部显示出来。declarecursorv_cursorisselect*fromemp;beginforv_empinv_cursorloopdbms_output.put_line(v_emp.ename);endloop;end;7.编写一个程序块,将emp表中前5人的名字显示出来。dec
14、larecursorv_cursorisselect*fromemp;v_countnumber:=1;beginforv_empinv_cursorloopdbms_output.put_line(v_emp.ename);v_count:=v_count+1;exitwhenv_count>5;endloop;end;8.编写一个程序块,接受一个雇员名,从emp表中显示该雇员的工作岗位与薪水,若输入的雇员名不存在,显示“该雇员不存在”信息。declarev_empemp%rowtype;my_exceptionException;beginselect*
15、intov_empfromempwhereename='&name';raisemy_exception;exceptionwhenno_data_foundthendbms_output.put_line('该雇员不存在!');whenothersthendbms_output.put_line(v_emp.job
16、
17、'---'
18、
19、v_emp.sal);end;9.接受两个数相除并且显示结果,如果第二个数为0,则显示消息“除数不能为0”。declarev_dividendfloat;v_divisorfloat;v_resultfloat;my_excep
20、tionException;beginv_divid
此文档下载收益归作者所有