Oracle_PLSQL入门之案例实践

Oracle_PLSQL入门之案例实践

ID:42625661

大小:20.52 KB

页数:4页

时间:2019-09-19

Oracle_PLSQL入门之案例实践_第1页
Oracle_PLSQL入门之案例实践_第2页
Oracle_PLSQL入门之案例实践_第3页
Oracle_PLSQL入门之案例实践_第4页
资源描述:

《Oracle_PLSQL入门之案例实践》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、Oracle PL/SQL入门之案例实践  前面已经了解了关于PL/SQL编程的基础,本文将结合一个案例来加深对这些知识点的理解。  一.案例介绍  某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是emp表和dept表,两张表的结构如下:  要求如下:  1、按照上表结构建立相应的表,并每张表写入5组合法数据。  2、操纵相关表,使得“技术部”的员工的薪水上涨20%。  3、建立日志,追踪薪水变动情况。  4、建立测试包。  二.案例的分析与实现  从前面案例的介绍不难看出,要求1考察点为基本SQL语句;要求2主要考察复合查询;要求3是考察触发器的应用;要求4

2、的考察面相对多一些,不仅考察了包的创建,而且也考察了在PL/SQL中的测试方法。了解了这些考察的知识点,就可以一一去解决。  要求1:  首先根据前面表的结构可以创建两张表:  ——创建员工表createtableemp(emp_idnumber(5),emp_namevarchar2(20),emp_salarynumber(4));  ——部门表createtabledept(dept_idnumber(3),dept_namevarchar2(20),emp_idnumber(5));  建立了表之后就可以往表里面写数据了,这里把添加表记录的代码写入到相应的存储过程。/*给

3、emp表添加记录的存储过程*/createorreplaceprocedureins_table_emp(p_emp_idnumber,p_emp_namevarchar2,p_emp_salarynumber)asv_emp_idnumber:=p_emp_id;v_emp_namevarchar2(20):=p_emp_name;v_emp_salarynumber:=p_emp_salary;begin insertintoempvalues(v_emp_id,v_emp_name,v_emp_salary);endins_table_emp;/*给dept表添加记录的存储

4、过程*/createorreplaceprocedureins_table_dept(p_dept_idnumber,p_dept_namevarchar2,p_emp_idnumber)as v_dept_idnumber:=p_dept_id; v_dept_namevarchar2(20):=p_dept_name; v_emp_idnumber:=p_emp_id;begin insertintodeptvalues(v_dept_id,v_dept_name,v_emp_id);endins_table_emp;/*调用相应的存储过程实现记录添加*/begin ins_

5、table_emp(10000,'',4000); ins_table_emp(10001,'??èy',2300); ins_table_emp(10002,'3?t',3500); ins_table_emp(10003,'à???',3500); ins_table_emp(10004,'á?ò?',3500); ins_table_dept(111,'DD?t2?',10000); ins_table_dept(111,'DD?t2?',10001); ins_table_dept(111,'DD?t2?',10002); ins_table_dept(112,'??ê?

6、2?',10003); ins_table_dept(113,'êD3?2?',10004);end;  要求2:  给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工塞选出来,然后对这些员工的薪水进行相应的改动。依照这一思路,代码如下:  (需要注意的是:将要加薪的部门作为参数,这样的存储过程更有灵活性。)createorreplaceprocedureadd_salary(p_dept_namevarchar2)asv_dept_namevarchar2(20):=p_dept_name;begin updateempsetemp.EMP_SALARY=

7、emp.EMP_SALARY*1.2whereemp.EMP_IDin(selectemp.EMP_IDfromemp,deptwhereemp.EMP_ID=dept.EMP_IDanddept.DEPT_ID='??ê?2?'); endadd_salary;  要求3:  建立日志对薪水的变动情况形成一个追踪,也就是说,如果对某个职员的薪水进行变更就应该将其相应的变更记录全部记下来。如果对emp表的salary字段创建一个触发器,来监视对salary的更改,把每次更改进行记

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。