实验3:三轮乱弄版(2)
Oracle数据库管理与开发I 实验报告
dbms_output.put_line(v_sal); exception
when no_data_found then
dbms.output.put_line('员工不存在'); end;
--自己寫的
8. 创建一个存储过程,以员工号为参数,修改该员工的工资。若该员工属于10号部门,
则工资增加140元;若属于20号部门,则工资增加200元;若属于30号部门,则工资增加250元;若属于其他部门,则工资增长300元。
createorreplaceprocedure pro_sal_change(
v_employees_name in employees.employee_id%type) as
v_sal number; v_deptno number; begin
FOR v_emp IN c_emp LOOP CASE v_emp.department_id WHEN10THEN v_increment:=140; WHEN20THEN v_increment:=200; WHEN30THEN v_increment:=250; ELSE v_increment:=300; ENDCASE;
UPDATE employees SET salary=salary+v_increment WHERECURRENTOF c_emp; ENDLOOP; exception
when no_data_found then
dbms.output.put_line('员工不存在'); end;
9. 创建一个函数,以员工号为参数,返回该员工的工资。
CREATEORREPLACEFUNCTION func_emp_salary( p_empno employees.employee_id%type) RETURN employees.salary%type AS
v_sal employees.salary%type; BEGIN
SELECT salary INTO v_sal FROM employees WHERE employee_id=p_empno;
Oracle数据库管理与开发I 实验报告
RETURN v_sal; EXCEPTION
WHEN NO_DATA_FOUND THEN
RAISE_APPLICATION_ERROR(-20000,'There is not such an employee!'); END func_emp_salary;
10. 创建一个函数,以部门号为参数,返回该部门的平均工资;
createorreplacefunction dro_avg_salary( v_deptno emp.deptno%type) return emp.sal%type is
vr_sal emp.sal%type; begin
selectavg(sal) into vr_sal from emp where deptno = v_deptno; return vr_sal; end;
11. 创建一个函数,以员工号为参数,返回该员工所在部门的平均工资。
CREATEORREPLACEFUNCTION func_emp_dept_avgsal( p_empno employees.employee_id%type) RETURN employees.salary%type AS
v_deptno employees.department_id%type; v_avgsal employees.salary%type; BEGIN
SELECT department_id INTO v_deptno FROM employees WHERE employee_id=p_empno;
SELECTavg(salary) INTO v_avgsal FROM employees WHERE department_id=v_deptno; RETURN v_avgsal; EXCEPTION
WHEN NO_DATA_FOUND THEN
RAISE_APPLICATION_ERROR(-20000,'There is not such an employee!'); END func_emp_dept_avgsal;
Oracle数据库管理与开发I 实验报告
12. 在employees表上创建一个触发器,保证每天8:00~17:00之外的时间禁止对该表进
行DML操作。 --自己做
createorreplacetrigger trg_emp beforeinsertorupdateordelete on employees begin
if to_char(sysdate,'HH24:MI')NOTBETWEEN'08:00'AND'17:00' THEN
RAISE_APPLICATION_ERROR (-20005,'只能在正常的工作时间内进行改变。'); ENDIF; END trg_emp;
--自己寫的
13. 在employees表上创建一个触发器,当插入、删除或修改员工信息时,统计各个部门的
人数及平均工资,并输出。
createorreplacetrigger trg_emp_dept_stat afterinsertordeleteorupdateof salary on employees declare
v_count number; v_salary number(6,2); begin
if inserting or deleting or updating then
for v in(select department_id,count(*)num,avg(salary)avgsal groupby department_id)loop
dbms_output.put_line(v.department_id||''||v.num); endloop; end;
Oracle数据库管理与开发I 实验报告
[教师评语]:
…… 此处隐藏:565字,全部文档内容请下载后查看。喜欢就下载吧 ……
相关推荐:
- [学前教育]MC9S12XS256RMV1 xs128芯片手册4
- [学前教育]安东尼语录经典语录
- [学前教育]e级gps控制测量技术设计书
- [学前教育]苏教版2022-2022学年八年级下学期期末
- [学前教育]装修公司推广 营销
- [学前教育]家政服务合同(完整版)
- [学前教育]湖北省2016届高三联考语文试题
- [学前教育]爱立信无涯学习系统LTE题库1-LTE基础知
- [学前教育]揭秘大众柴油车作弊软件原理
- [学前教育]人才流失原因及对策分析
- [学前教育]房屋建筑施工工程劳务分包合同
- [学前教育]国际贸易实务试卷A卷09.6
- [学前教育]校园废品回收活动计划方案书范文格
- [学前教育]电大成本会计试题及答案
- [学前教育]大学物理实验 华南理工出版社 绪论答案
- [学前教育]爱丁堡产后抑郁量表
- [学前教育]液压冲击的危害、产生原因与防止方法(
- [学前教育]学生工作总结高一学生期中考试总结_020
- [学前教育]人民医院医疗废物管理规章制度大全
- [学前教育]阳光维生素的巨大抗癌潜能阅读题答案.d
- 马云在云锋基金江苏论坛闭幕式的发言
- 试论小学体育教育中的心理健康教育-教
- 语文A版一年级下册《语文乐园一》教学
- 2021四川大学物理化学考研真题经验参考
- [人教A版]2015-2016学年高中数学 第二
- 终端网点销售返利协议书
- 江苏省2015年眼科学主治医师青光眼考试
- 2017年部编人教版八年级语文上册教案
- 十一中学七年级英语上册Unit7Howmuchar
- 以赛促教的创新性实验教学机制建设实践
- 平凉市崆峒区2015七年级下生物期末试题
- 琶洲(地块五)A、B塔楼1、2#塔吊基础
- 一级医院工作制度与人员岗位职责
- 2018北京西城区高三二模理科数学试题及
- 炒股密码线技术 - 图文
- 职高学生生涯发展辅导教案
- 语文人教版四年级上册8 世界地图引出的
- 最新最新人教版二年级上册全册数学教案
- 2017高考英语全国2卷精彩试题(有问题
- 普通心理学笔记




