数据库案例分析

原创 2004年11月03日 17:58:00

档案管理系统——学籍翻译系统
一.案例介绍
  (部分举例)学籍管理数据库有两张表,是关于某高校学生信息和成绩信息的,它们分别是emp表和

dept表,两张表的结构如下:
    (1)学生基本信息表Student
    (2)成绩表Grade
  要求如下:
  1、按照上表结构建立相应的表,并每张表写入5组合法数据。
  2、操纵相关表,使得“成绩优秀(90分以上)的”的学生的奖学金补助上涨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;
  /*调用相应的存储过程实现记录添加*/
  begin
   ins_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) 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_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 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;

数据库设计案例分析

一、树型关系的数据表   不少程序员在进行数据库设计的时候都遇到过树型关系的数据,例如常见的类别表,即一个大类,下面有若干个子类,某些子类又有子类这样的情况。当类别不确定,用户希望可以在任意类别下添...
  • u011130752
  • u011130752
  • 2016年06月30日 09:39
  • 6583

SQL数据库实例

  • 2013年01月19日 07:19
  • 16.02MB
  • 下载

几个数据库案例分析

We will learn about several  function in the first place.firstly,character string function  secondly...
  • gz2008gz
  • gz2008gz
  • 2009年07月25日 10:38
  • 6428

数据挖掘案例分析(1)-Apriori算法

数据挖掘案例分析(1)-Apriori算法 前言:由于单单学习算法太过于枯燥和乏味,所以我们采取的学习方法是练中学,本人也是之前一点关于数据挖掘的算法知识没有学习,因此可能在理解上还不是很到位,我会...
  • u012835097
  • u012835097
  • 2016年09月07日 15:26
  • 874

电子商务网站商品推荐案例分析

本案例的主要目的是通过分析用户和网站数据,使用数据挖掘技术,分析老客户忠诚度下降的原因。 建立客户忠诚度模型,提高其忠诚度。 一、分析方法和过程 数据来源:客户信息、交易信息分别存放在网...
  • qq_23617681
  • qq_23617681
  • 2016年05月20日 10:46
  • 1090

JVM调优案例分析与实战

一、内存溢出 1、堆内存溢出 模拟代码以及JVM设置: public class OOMTest {     //JVM设置   ...
  • u010372867
  • u010372867
  • 2016年11月28日 16:47
  • 886

商务智能分析案例

商务智能分析案例 商业智能分析背景及总体解决方案 企业工作内容及交付物   设计阶段 基本设计(basic engineering)或分析和平面设计(analyt...
  • wolaiye320
  • wolaiye320
  • 2016年05月24日 17:08
  • 1103

客户分析细分案例

按销售额划分,大多数25-35岁之间的客户恐怕都要归入较差一类。这部分多是正在求学或刚刚走出校门的年轻人,收入低,而且还要偿还求学期间所欠贷款。但是加拿大RBC银行预见这些客户中有些人将来很可能是银行...
  • housheng3319
  • housheng3319
  • 2014年01月11日 12:37
  • 1062

微信运营案例分析

活动前期认知和设计: 1产品定位 2目标人群 3选择利益点4文案的设计 注意标题 一、活动前期的认知和精细化设计 公众号定位:分享微信群讲座信息及干货资源...
  • byfworking
  • byfworking
  • 2016年04月24日 10:03
  • 4224

大型网站典型故障案例分析

写日志也会引发故障故障现象:某应用服务器集群发布后不久就出现多台服务器相继报警,硬盘可用空间低于警戒值,并且很快有服务器宕机,登录到线上服务器,发现log文件夹里的文件迅速增加,不断消耗磁盘空间。 原...
  • Edwingu
  • Edwingu
  • 2015年03月09日 23:04
  • 1561
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据库案例分析
举报原因:
原因补充:

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