Oracle PL/SQL入门案例实践

来源:asp之家 时间:2010-07-18 13:13:00 

前面已经了解了关于PL/SQL编程的基础,本文将结合一个案例来加深对这些知识点的理解。

一. 案例介绍

  某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是emp表和dept表,两张表的结构如下:


  要求如下:

  1、按照上表结构建立相应的表,并每张表写入5组合法数据。

  2、操纵相关表,使得“技术部”的员工的薪水上涨20%。

  3、建立日志,追踪薪水变动情况。

  4、建立测试包。

  二. 案例的分析与实现

  从前面案例的介绍不难看出,要求1考察点为基本SQL语句;要求2主要考察复合查询;要求3是考察触发器的应用;要求4的考察面相对多一些,不仅考察了包的创建,而且也考察了在PL/SQL中的测试方法。了解了这些考察的知识点,就可以一一去解决。

  要求1:

  首先根据前面表的结构可以创建两张表:

  ——创建员工表


  ——部门表


  建立了表之后就可以往表里面写数据了,这里把添加表记录的代码写入到相应的存储过程。


  要求2:

  给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工塞选出来,然后对这些员工的薪水进行相应的改动。依照这一思路,代码如下:

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


  要求3:

  建立日志对薪水的变动情况形成一个追踪,也就是说,如果对某个职员的薪水进行变更就应该将其相应的变更记录全部记下来。如果对emp表的salary字段创建一个触发器,来监视对salary的更改,把每次更改进行记录,这样就达到了要求3的目的了。


  要求4:

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

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

  2、插入测试表的方法。即创建一个临时的中间表,然后把所有涉及到的中间变量的结果都作为记录插入到中间表中,这样可以查询表中的结果来观察程序的执行情况。

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

  这里准备使用第二种方法来建立一个测试包,PL/SQL里包的概念类似于面向对象里的类的概念,包将一组操作和属性封装在一起,不仅增强了程序的模块化,而且由于封装了更多的操作和属性而提高了执行效能。建立一个PL/SQL需要两个步骤:首先要建立包头,类似于建立一个类的头文件,里面主要对包中的过程,函数和变量的声明;第二部分主要是包体部分,实现前面声明的过程和函数,另外还需要对包进行初始化等工作。

  根据这一思路,建立测试包如下:


  三.小结

  综合前面对4个问题的解答,基本把PL/SQL的主要部分融会进来了,虽然很多地方只是涉及到比较粗浅的层次,但是有了这一基础,深入下去也是不难的。

  总之,PL/SQL编程与其他语言编程有一定的区别,读者只有把握好其特点才能更好的掌握数据库开发的方面知识。

标签:oracle,sqsl,案例
0
投稿

猜你喜欢

  • “Unable to read local eventlog (reason:事件日志文件已在读取时间更改)”解决办法

    2009-08-27 13:12:00
  • mysql 安装使用小记

    2011-02-23 12:33:00
  • Ie6不支持max的解决办法

    2008-12-31 13:11:00
  • 教你设计大型Oracle数据库

    2009-07-02 12:31:00
  • MySQL数据库临时文件究竟储存在哪里

    2009-09-06 12:11:00
  • Mootools 1.2教程(6)——操纵HTML DOM元素

    2008-11-20 13:19:00
  • Sql Server 无日志文件附加

    2010-05-30 11:23:00
  • XML十项特点

    2008-04-05 13:49:00
  • asp如何定义参数?

    2010-05-16 15:20:00
  • 如何从数据库断开recordset,提高运行速度?

    2009-11-15 20:01:00
  • 图片预加载效果的实现

    2008-06-16 12:08:00
  • 全文译稿 Windows Internet Explorer 8 性能优化白皮书

    2010-04-23 20:13:00
  • 个人从事设计行业40句观感

    2008-04-07 13:58:00
  • MSSQL存储过程解秘过程全析

    2010-07-05 08:49:00
  • 使用一条INSERT语句完成多表插入

    2010-03-18 11:08:00
  • SQL学习笔记五去重,给新加字段赋值的方法

    2011-09-30 11:53:28
  • Sun正式发布MySQL 5.1版 简化数据库应用

    2008-12-11 15:15:00
  • 用mysql做站点时怎样记录未知错误的发生

    2009-01-14 13:16:00
  • Access数据库中“所有记录中均未找到搜索关键字”的解决方法

    2011-04-14 10:31:00
  • 大牌 Banner 设计欣赏(468x60)

    2008-01-20 13:02:00
  • asp之家 网络编程 m.aspxhome.com