Oracle PL/SQL入门之案例实践

原创 2004年09月30日 17:04:00

 一. 案例介绍

  某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是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) as
v_emp_id number:=p_emp_id;
v_emp_name varchar2(20):=p_emp_name;
v_emp_salary number:=p_emp_salary;
begin
 insert 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)

as
 v_dept_id number:=p_dept_id;
 v_dept_name varchar2(20):=p_dept_name;
 v_emp_id number:=p_emp_id;
begin
 insert into dept values (v_dept_id,v_dept_name,v_emp_id);
end ins_table_emp;

/*调用相应的存储过程实现记录添加*/

execute ins_table_emp(10000,'a',4000);
execute ins_table_emp(10001,'b',2300);
execute ins_table_emp(10002,'c',3500);
execute ins_table_emp(10003,'d',3500);
execute ins_table_emp(10004,'e',3500);
execute ins_table_dept(111,'张三',10000);
execute ins_table_dept(111,'张三',10001);
execute ins_table_dept(111,'张三',10002);
execute ins_table_dept(112,'赵六',10003);
execute ins_table_dept(113,'宋七',10004);

 

  要求2:

  给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工塞选出来,然后对这些

员工的薪水进行相应的改动。依照这一思路,代码如下:

  (需要注意的是:将要加薪的部门作为参数,这样的存储过程更有灵活性。)

create or replace procedure add_salary(p_dept_name varchar2) as
v_dept_name varchar2(20):=p_dept_name;
begin
 update 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_name=v_dept_nam);
end add_salary;

  要求3:
create table salary(old_s number(4), new_s number(4), differ_s number(4));
  建立日志对薪水的变动情况形成一个追踪,也就是说,如果对某个职员的薪水进行变更就应该将其相应的

变更记录全部记下来。如果对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.EMP_salary-:old.EMP_salary;

insert into salary values(:old.EMP_salary,:new.EMP_salary,salary_balance);
end print_salary_change;

 


execute add_salary('张三');就可以看到salary表的变化。
  要求4:

  与其他语言(c/c++等)相比,PL/SQL的测试有其不同之处,归纳下来有三种方法:

  1、使用DBMS_OUTPUT包的PUT_LINE方法来显示中间变量,以此来观察程序是否存在逻辑错误。

  2、插入测试表的方法。即创建一个临时的中间表,然后把所有涉及到的中间变量的结果都作为记录插入到

中间表中,这样可以查询表中的结果来观察程序的执行情况。

  3、使用异常处理手段,对可疑的程序段使用begin … end ,然后可以在exception里进行异常捕获处理。

  这里准备使用第二种方法来建立一个测试包,PL/SQL里包的概念类似于面向对象里的类的概念,包将一组

操作和属性封装在一起,不仅增强了程序的模块化,而且由于封装了更多的操作和属性而提高了执行效能。建

立一个PL/SQL需要两个步骤:首先要建立包头,类似于建立一个类的头文件,里面主要对包中的过程,函数和

变量的声明;第二部分主要是包体部分,实现前面声明的过程和函数,另外还需要对包进行初始化等工作。

  根据这一思路,建立测试包如下:
create table debugtable (d_numberOfLine number,d_description varchar2(20),d_valueOfvariable

varchar2(20));
/*包头部分*/
create or replace package debug as
procedure debug(v_description varchar2,v_valueOfvariable varchar2)
 procedure reset;
 v_numberOfLine number;
end debug;
/*包体部分*/
create or replace package body debug as
procedure debug(v_description varchar2,v_valueOfvariable varchar2) is
begin
 insert into debugtable
 values(v_numberOfLine,v_description,v_valueOfvariable);
 v_numberOfLine:=v_numberOfLine+1;
end debug;
procedure reset is
begin
 v_numberOfLine:=1;
 delete from debugtable;
end reset;
/*初始化部分*/
begin
 reset;
end debug;

PL/SQL入门——基础的增删改查

最近由于做毕设,又重新看了一遍王珊和萨师煊老师编写的《数据库原理概论》(第四版),再利用PL/SQL将书中最基础的增删改查实现了一遍 所有操作是对以下三个表进行的 学生表Student ...
  • u013253278
  • u013253278
  • 2016年04月11日 12:41
  • 2680

PL/SQL基础语法入门

先前安装了PL/SQL软件 PL/SQL全称为Procedural Language/SQL。 PL/SQL也是一种程序语言,叫做过程化SQL语言,是Oracle数据库对SQL语句...
  • chance2015
  • chance2015
  • 2015年12月26日 18:20
  • 2357

PL/SQL基础(1):语法

目录 1、什么是PL/SQL? 2、PL/SQL基本结构 3、PL/SQL符号定义 4、PL/SQL数据类型 5、PL/SQL条件句法 6、PL/SQL循环 什么是PL/SQL? PL/SQL...
  • dou3516
  • dou3516
  • 2016年09月03日 19:29
  • 713

PL/SQL 综合复习题(2)

PL/SQL 综合复习题(2)案例介绍某数据库有三张表,是关于某公司员工资料、薪水,部门和工作地点信息的,它们分别是emp表, dept表,和location表. 三张表的结构如下:Emp: 用于存储...
  • J_A_V_A
  • J_A_V_A
  • 2007年02月07日 23:11
  • 1555

Oracle PL/SQL从入门到精通 pdf版本

  • 2014年09月28日 16:28
  • 14.66MB
  • 下载

Oracle PL/SQL从入门到精通

  • 2012年11月29日 10:34
  • 588KB
  • 下载

PL/SQL各个窗口的区别(转)

PL/SQL各窗口区别
  • u013249984
  • u013249984
  • 2017年09月14日 11:02
  • 221

sql参考

drop database pushmarketing; create database pushmarketing; use pushmarketing; -- -- Table struc...
  • guotong1988
  • guotong1988
  • 2012年11月22日 13:50
  • 2357

Oracle PL/SQL入门之案例实践

一. 案例介绍    某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是emp表和dept表,两张表的结构如下:    要求如下:    1、按照上表结构建立相应的表,并每张表写入5...
  • wumourong
  • wumourong
  • 2007年05月23日 22:43
  • 530

oracle pl/sql入门之案例实践

 前面已经了解了关于pl/sql编程的基础,本文将结合一个案例来加深对这些知识点的理解。一. 案例介绍  某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是emp表和dept表,两张...
  • success_dream
  • success_dream
  • 2007年12月25日 21:58
  • 493
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Oracle PL/SQL入门之案例实践
举报原因:
原因补充:

(最多只允许输入30个字)