plsql测试—参考答案.docVIP

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
plsql测试—参考答案.doc

1、创建一个emp1表,其结构和数据与emp表完全一致。用游标完成操作:显示工资低于1500的职员信息,并显示如果给他们涨30%工资后的工资。 create table emp1 as select * from emp; set serveroutput on declare cursor cur is select * from emp where sal1500; begin for v_counter in cur loop dbms_output.put_line(v_counter.empno|| ||v_counter.ename|| ||v_counter.mgr|| ||v_counter.hiredate|| ||v_m|| ||v_counter.sal|| ||v_counter.sal*1.3); end loop; end; 2、编写一个pl/sql块,输出所有员工的员工名、员工号、工资和部门号。declare cursor c_emp is select * from emp; begin for v_emp in c_emp loop dbms_output.put_line(v_emp.ename|| ||v_emp.empno|| ||v_emp.deptno|| ||v_emp.sal); end loop; end; 3、查询名为“smith”的员工信息,并输出其员工号、工资、部门号。如果该员工不存在,则插入一条新记录,员工号为2007,员工名为“smith”,工资为1500,部门号为10。如果存在多个名为“smith”的员工,则输出所有名为“smith”的员工号、工资和部门号。Declare v_emp emp%rowtype; begin select * into v_emp from emp where ename=smith; dbms_output.put_line(v_emp.empno|| ||v_emp.sal|| ||v_emp.deptno); exception when no_data_found then insert into emp(empno,ename,sal,deptno) values(2007,smith,1500,10); when too_many_rows then for v in (select * from emp where ename=smith) loop dbms_output.put_line(v.empno|| ||v.sal|| ||v.deptno); end loop; end; 4、创建一个存储过程,以员工号为参数,输出该员工的工资。create or replace procedure showsal(p_empno emp.empno%type) as v_sal emp.sal%type; begin select sal into v_sal from emp where empno=p_empno; dbms_output.put_line(v_sal); end; begin showsal(7844); end; 5、创建一个函数,以部门号为参数,返回该部门的平均工资;create or replace function fun_avgsal(p_deptno emp.deptno%type) return emp.sal%type as v_sal emp.sal%type; begin select avg(sal) into v_sal from emp where deptno=p_deptno; return v_sal; end; begin dbms_output.put_line (fun_avgsal(10)); end; 6、创建一个函数,以员工号为参数,返回该员工所在部门的平均工资。create or replace function fun_sal(p_empno emp.empno%type) return emp.sal%type as v_sal emp.sal%type; begin select avg(sal) into v_sal from emp where deptno= (select deptno from emp where empno=p_empno); return v_sal; end; begin dbms_output.put_line (fun_sal (7844)); end; 7、在emp表上创建一个触发器,当插入、删除或修改员工信息时

文档评论(0)

ziyouzizai + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档