如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
Oracle作业题一.创建一个简单的PL/SQL程序块使用不同的程序块组件工作使用编程结构编写PL/SQL程序块处理PL/SQL程序块中的错误1.编写一个程序块,从emp表中显示名为“SMITH”的雇员的薪水和职位。declarev_empemp%rowtype;beginselect*intov_empfromempwhereename='SMITH';dbms_output.put_line(v_emp.job||'--'||v_emp.sal);end;2.编写一个程序块,接受用户输入一个部门号,从dept表中显示该部门的名称与所在位置。declarev_deptdept%rowtype;beginselect*intov_deptfromdeptwheredeptno=&部门号;dbms_output.put_line(v_dept.dname||'--'||v_dept.loc);end;3.编写一个程序块,利用%type属性,接受一个雇员号,从emp表中显示该雇员的整体薪水(即,薪水加佣金)。declarev_salemp.sal%type;beginselectsal+commintov_salfromempwhereempno=&雇员号;dbms_output.put_line(v_sal);end;4.编写一个程序块,利用%rowtype属性,接受一个雇员号,从emp表中显示该雇员的整体薪水(即,薪水加佣金)。declarev_empemp%rowtype;beginselect*intov_empfromempwhereempno=&雇员号;dbms_output.put_line(v_emp.sal+v_emp.comm);end;5.某公司要根据雇员的职位来加薪,公司决定按下列加薪结构处理:DesignationRaise-----------------------Clerk500Salesman1000Analyst1500Otherwise2000编写一个程序块,接受一个雇员名,从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'thenupdateempsetsal=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人的名字显示出来。declarecursorv_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*intov_empfromempwhereename='&name';raisemy_exception;exceptionwhenno_data_foundthendbms_output.put_line('该雇员不存在!');whenothersthendbms_output.put_line(v_emp.job||'---'||v_emp.sal);end;9.接受两个数相除