全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
OraclePL/SQL入门之案例实践前面已经了解了关于PL/SQL编程的基础,本文将结合一个案例来加深对这些知识点的理解。一 案例介绍某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是emp表和dept表,两张表的结构如下:要求如下:1、按照上表结构建立相应的表,并每张表写入5组合法数据。2、操纵相关表,使得“技术部”的员工的薪水上涨20%。3、建立日志,追踪薪水变动情况。4、建立测试包。二 案例的分析与实现从前面案例的介绍不难看出,要求1考察点为基本SQL语句;要求2主要考察复合查询;要求3是考察触发器的应用;要求4的考察面相对多一些,不仅考察了包的创建,而且也考察了在PL/SQL中的测试方法。了解了这些考察的知识点,就可以一一去解决。要求1:首先根据前面表的结构可以创建两张表:创建员工表create table emp (emp_id number(5), emp_name varchar2(20), emp_salary number(4);部门表create table dept (dept_id number(3), dept_name varchar2(20), emp_id number(5);建立了表之后就可以往表里面写数据了,这里把添加表记录的代码写入到相应的存储过程。/*给emp表添加记录的存储过程*/create or replace procedure ins_table_emp(p_emp_id number,p_emp_name varchar2,p_emp_salary number) asv_emp_id number:=p_emp_id;v_emp_name varchar2(20):=p_emp_name;v_emp_salary number:=p_emp_salary;begininsert into emp values (v_emp_id,v_emp_name,v_emp_salary);end ins_table_emp;/*给dept表添加记录的存储过程*/create or replace procedure ins_table_dept(p_dept_id number,p_dept_name varchar2,p_emp_id number) asv_dept_id number:=p_dept_id;v_dept_name varchar2(20):=p_dept_name;v_emp_id number:=p_emp_id;begininsert into dept values (v_dept_id,v_dept_name,v_emp_id);end ins_table_emp;/*调用相应的存储过程实现记录添加*/beginins_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,?2?,10003);ins_table_dept(113,D3?2?,10004);end;要求2:给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工塞选出来,然后对这些员工的薪水进行相应的改动。依照这一思路,代码如下:(需要注意的是:将要加薪的部门作为参数,这样的存储过程更有灵活性。)create or replace procedure add_salary(p_dept_name varchar2) asv_dept_name varchar2(20):=p_dept_name;beginupdate emp set emp.EMP_SALARY=emp.EMP_SALARY*1.2 where emp.EMP_ID in (select emp.EMP_ID from emp,dept where emp.EMP_ID=dept.EMP_ID and dept.DEPT_ID=?2?);end add_salary;要求3:建立日志对薪水的变动情况形成一个追踪,也就是说,如果对某个职员的薪水进行变更就应该将其相应的变更记录全部记下来。如果对emp表的salary字段创建一个触发器,来监视对salary的更改,把每次更改进行记录,这样就达到了要求3的目的了。create or replace trigger print_salary_change before delete or insert or update on emp-触发事件for each row- 每修改一行都需要调用此过程declare -只有触发器的声明需要declare,过程和函数都不需要salary_balance number;begin-:new 与:old分别代表该行在修改前和修改后的记录salary_balance=:new.salary=:old.salary;dbms_output.PUT_LINE(old salary is: | :old.salary);dbms_output.PUT_LINE(old salary is: | :new.salary);dbms_output.PUT_LINE(old salary is: | to_char(salary_balance);end print_salary_change;要求4:与其他语言(c/c+等)相比,PL/SQL的测试有其不同之处,归纳下来有三种方法:1、使用DBMS_OUTPUT包的PUT_LINE方法来显示中间变量,以此来观察程序是否存在逻辑错误。2、插入测试表的方法。即创建一个临时的中间表,然后把所有涉及到的中间变量的结果都作为记录插入到中间表中,这样可以查询表中的结果来观察程序的执行情况。3、使用异常处理手段,对可疑的程序段使用begin end ,然后可以在exception里进行异常捕获处理。这里准备使用第二种方法来建立一个测试包,PL/SQL里包的概念类似于面向对象里的类的概念,包将一组操作和属性封装在一起,不仅增强了程序的模块化,而且由于封装了更多的操作和属性而提高了执行效能。建立一个PL/SQL需要两个步骤:首先要建立包头,类似于建立一个类的头文件,里面主要对包中的过程,函数和变量的声明;第二部分主要是包体部分,实现前面声明的过程和函数,另外还需要对包进行初始化等工作。根据这一思路,建立测试包如下:/*包头部分*/create or replace package debug asprocedure debug(v_description varchar2,v_valueOfvariable varchar2)procedure reset;v_numberOfLine number;end debug;/*包体部分*/create or replace package body debug asprocedure debug(v_description varchar2,v_valueOfvariable varchar2) isbegininsert into debugtablevalues(v_numberOfLine,v_description,v_valueOfvariable);v_numberOfLine:=v_numberOfLine+1;end debug;procedure reset isbeginv_numberOfLine:=1;delete from debu
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 情态动词疑问试题及答案
- 中医急诊急救试题及答案
- DB1309T 328-2025 奶牛场粪污无害化处理技术规范
- 备战2026年高考英语考试易错题(新高考)【消灭易错】代词(原卷版)(3大题组)
- 2025年折纸熊猫面试真题及答案
- 2025年材料科学研究员招聘面试题库及参考答案
- 2025年小程序开发者招聘面试参考题库及答案
- 2025年广告文案创作岗位招聘面试参考试题及参考答案
- 2025年铁道工程师岗位招聘面试参考试题及参考答案
- 2025年战略计划专员岗位招聘面试参考题库及参考答案
- 全国大学生职业规划大赛《农村金融》专业生涯发展展示【高职(专科)】
- 2025年人教版三年级上册道德与法治全册知识点(新教材)
- 2025全国交管12123学法减分考试题库带参考答案
- 2025年四川省拟任县处级领导干部任职资格试题及参考答案
- 二元一次方程组的应用(1)课件北师大版八年级数学上册
- 第一讲 决胜“十四五”奋发向前行
- 生产现场5S管理实施方案详解
- 瑞幸咖啡财务舞弊案例分析
- 《人工智能语言与伦理》章节测试题及答案
- 无人机生产设备选型与维护方案
- 北京某机场交通中心内装修施工组织设计方案
评论
0/150
提交评论