《数据库概论》实验指导书(2015) 下载本文

内容发布更新时间 : 2024/12/23 1:24:44星期一 下面是文章的全部内容请认真阅读。

《数据库系统概论》实验报告书 安徽工业大学计算机学院

15/19

《数据库系统概论》实验报告书 安徽工业大学计算机学院

实验五:Oracle存储过程与触发器

[ 实验日期 ] 年 月 日 [ 实验目的 ]

通过实验进一步理解和掌握Oracle数据库的存储过程和触发器。 [ 实验内容 ]

4. 存储过程与触发器:

例7-1: (存储过程) 创建一个显示学生总人数的存储过程。

例7-2: (存储过程) 创建显示学生信息的存储过程STUDENT_LIST,并引用STU_COUNT存储过程。 例7-3: (存储过程) 创建一个显示学生平均成绩的存储过程。 例7-4: (存储过程) 创建显示所有学生平均成绩的存储过程。 例7-5: (修改数据库表) 在Student表中增加SAVG(N,6,2) 字段。

例7-6: (存储过程) 创建存储过程,计算每个学生的平均成绩保存到学生表SAVG字段中。 例7-7: (触发器) 当更新学生成绩表SCORE中的学生成绩时,自动计算该学生的平均成绩保存到学生表SAVG字段中。

例7-8: (触发器) 创建包含插入、删除、修改多种触发事件的触发器DML_LOG,对SCORE表的操作进行记录。用INSERTING、DELETING、UPDATING谓词来区别不同的DML操作。 先创建事件记录表LOGS,该表用来对操作进行记录。该表的字段含义解释如下: LOG_ID:操作记录的编号,数值型,它是该表的主键,自动增1,可由序列自动生成。 LOG_TABLE:进行操作的表名,字符型,非空,该表设计成可以由多个触发器共享使用。比如我们可以为Student表创建类似的触发器,同样将操作记录到该表。 LOG_DML:操作的动作,即INSERT、DELETE或UPDATE三种之一。

LOG_KEY_ID:操作时表的主键值,数值型。之所以记录表的主键,是因为主键是表的记录的惟一标识,可以识别是对哪一条记录进行了操作。对于Score表,主键是由SNO_CNO构成。 LOG_DATE:操作的日期,日期型,取当前的系统时间。

LOG_USER:操作者,字符型,取当时的操作者账户名。比如登录SCOTT账户进行操作,在该字段中,记录账户名为SCOTT。

16/19

《数据库系统概论》实验报告书 安徽工业大学计算机学院

[ 实验要求 ]

① 创建、调试和修改、调用和执行Oracle存储过程; ② 创建、调试和修改、测试Oracle触发器。 [ 实验方法 ]

① 将实验需求用SQL语句表示; ② 执行SQL语句;

③ 查看执行结果,如果结果不正确,进行修改,直到正确为止。

[ 实验总结 ]

① SQL语句以及执行结果; ② 对重点实验结果进行分析; ③ 实验中的问题和提高; ④ 收获与体会。

17/19

《数据库系统概论》实验报告书 安徽工业大学计算机学院

18/19

《数据库系统概论》实验报告书 安徽工业大学计算机学院

19/19