内容发布更新时间 : 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