数据库案例分析

数据|数据库

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

时间: 2024-09-20 19:15:10

数据库案例分析的相关文章

【阿里在线技术峰会】罗龙九:云数据库十大经典案例分析

本文根据阿里云资深DBA专家罗龙九在首届阿里巴巴在线峰会的<云数据库十大经典案例分析>的分享整理而成.罗龙九以MySQL数据库为例,分析了自RDS成立至今,用户在使用RDS过程中最常见的问题,包括:索引.SQL优化.锁.延迟.参数优化.连接数.CPU.Iops.磁盘.内存等.罗龙九通过对十大经典案例的总结,还原问题原貌,给出分析问题的思路,旨在帮助用户在使用RDS的路上少一些弯路,多一些从容. 直播视频 (点击图片查看视频) 幻灯片下载:点此进入 以下为整理内容. 案例一:索引 今天之所以将索

数据库上云经典案例分析

本文PPT来自阿里云技术专家玄惭于10月14日在2016年杭州云栖大会上发表的演讲,分享主题为<数据库上云经典案例分析>. 玄惭花名出自<天龙八部>,2012年加入阿里云RDS并负责线上的稳定,历年RDS双11的负责人,目前负责RDS专家服务.在这次分享上,玄惭用五个经典案例与我们分享数据库上云中的经验与教训. 案例一中,某客户正在将本地的业务系统迁移上云,但在RDS上运行时间明显要比线下自建数据库运行时间要慢1倍,导致客户系统割接延期的风险.经过经验分析和测试验证后,发现参数配置

《OSPF网络设计解决方案(第2版)》一2.7 案例分析:使用链路状态数据库

2.7 案例分析:使用链路状态数据库 OSPF网络设计解决方案(第2版) 在本章之前的内容中,我们已经学习到了如何使用LSA在OSPF路由器之间发送有关链路的信息.这些LSA被存储于路由器内部的一个数据库中,并且一条LSA将作为该数据库的一条记录. 图2-16给出了本节案例分析所使用的OSPF网络拓扑. 例2-6显示了在HAL9000路由器上使用show ip ospf database命令的输出条目. 注意这里的输出并未包含图2-16中其他区域的信息(即只有区域0的条目),这是因为路由器HAL

Java EE应用程序在Glassfish上的性能调优案例分析

Java EE应用的性能问题对严肃的项目和产品来说是一个非常重要的问题.特别是企业级的应用,并发用户多,数据传输量大,业务逻辑复杂,占用系统资源多,因此性能问题在企业级应用变得至关重要,它和系统的稳定性有着直接的联系.更加重要的是,性能好的应用在完成相同任务的条件下,能够占用更少的资源,获得更好的用户体验,换句话说,就是能够节省费用和消耗,获得更高的利润. 要获得更好的性能,就需要对原来的系统进行性能调优.对运行在Glassfish上的JavaEE应用,调优是一件相对复杂的事情.在调优以前必须要

ORA-04031错误导致宕机案例分析

今天遇到一起ORACLE数据库宕机案例,下面是对这起数据库宕机案例的原因进行分析.解读.分析过程中顺便记录一下这个案例的前因后果,攒点经验值,培养一下分析.解决问题的能力.   案例环境:      操作系统 :Oracle Linux Server release 5.7 64 bit    数据库版本:Oracle Database 10g Release 10.2.0.4.0 - 64bit Production   案例分析: 收到告警去检查数据库时,发现实例已经宕机.检查告警日志,发现

案例分析:基于消息的分布式架构

原文:案例分析:基于消息的分布式架构 美国计算机科学家,LaTex的作者Leslie Lamport说:"分布式系统就是这样一个系统,系统中一个你甚至都不知道的计算机出了故障,却可能导致你自己的计算机不可用."一语道破了开发分布式系统的玄机,那就是它的复杂与不可控.所以Martin Fowler强调:分布式调用的第一原则就是不要分布式.这句话看似颇具哲理,然而就企业应用系统而言,只要整个系统在不停地演化,并有多个子系统共同存在时,这条原则就会被迫打破.盖因为在当今的企业应用系统中,很难

《OSPF网络设计解决方案(第2版)》一2.8 案例分析:OSPF网络的构建和收敛

2.8 案例分析:OSPF网络的构建和收敛 OSPF网络设计解决方案(第2版) 之前的两个案例分析回顾了链路状态数据库以及它的建立过程.本节将通过新的案例分析来讨论本章之前已经介绍过的一些概念,除此以外,本节还将讨论如何构建一个简单的OSPF网络以及网络的收敛. 假设 MatrixNet 是一家专注于影视特效的高科技动画公司,并想要在其核心网络内实施 OSPF.该公司的核心网络内拥有三台通过以太网相互连接的路由器,如图2-19所示. 在本节案例中,你需要在3台Cisco路由器上配置OSPF.但必

15年老司机的DPM数据库性能分析产品研发之路

本文根据DBAplus社群第87期线上分享整理而成.   讲师介绍  邹德裕 轻维软件首席专家   DBAplus社群联合发起人,OraZ产品作者.Oracle OCM. 15年运维管理经验,在数据库诊断.故障排除.优化.架构设计等方面具有丰富的经验.   主题简介: 1.运维中常见的场景及对应解决案例 2.解密DPM数据库性能分析平台   本次我给大家带来的主题分享为<15年老司机的DPM数据库性能分析产品研发之路>.   我将通过Oracle在实际生产中常见的运维场景及问题处理案例,解析如

MySQL运维案例分析:Binlog中的时间戳

背景 众所周知,在Binlog文件中,经常会看到关于事件的时间属性,出现的方式都是如下这样的. #161213 10:11:35 server id 11766 end_log_pos 263690453 CRC32 0xbee3aaf5 Xid = 83631678 我们清楚地知道,161213 10:11:35表示的就是时间值,但除此之外呢?还能知道它的什么信息呢? 案例分析 先从一个典型的案例入手来讲述其中的细节,比如曾经在Galera Cluster碰到的一个问题,可以先看一段Binlo