《数据库与信息系统》SQL语言-7触发器_第1页
《数据库与信息系统》SQL语言-7触发器_第2页
《数据库与信息系统》SQL语言-7触发器_第3页
《数据库与信息系统》SQL语言-7触发器_第4页
《数据库与信息系统》SQL语言-7触发器_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、SQL与可编程对象4触发器为什么需要触发器?触发器一般用来监视数据库,以便及时进行一些数据维护工作。例如:实现比数据完整性约束更为复杂的其他限制;级联修改数据库中相关的表数据;及时取消不合适的更新操作,防止恶意或错误地使用数据库。例子:当某个学生选了某一门课程之后,需要对数据库中的数据进行以下修改:选课表中插入一条记录将选择该课程的选课人数增加1选课人数的更新能不能自动完成呢?数据库中的部分关系模式:学生(学号,姓名,)选课(学号,课程号,成绩)课程(课程号,课程名,选课人数,)触发器的定义触发器是一种特殊的存储过程。当对数据库进行更新操作时被触发自动执行。不需要显式调用!InsertUpda

2、teDelete更新操作设置触发器需要指明以下两方面内容:什么条件下触发?触发后执行时的动作触发器的分类建在表上,执行更新数据操作时触发。视图和临时表都不支持触发器。按触发时刻分两类:InsertUpdateDelete触发器AFTER触发器: 在表中数据修改之后触发,默认类型。BEFORE触发器:在表中数据修改以前触发。使用 SQL语句创建触发器CREATE TRIGGER 触发器名BEFORE|AFTER INSERT|UPDATE|DELETEON 表名 FOR EACH ROWSQL语句段;触发事件触发时间触发范围:行级触发触发后执行的语句需要建立触发器的表CREATE TRIGGER

3、 tri_courseenrollAFTER INSERT ON courseenrollFOR EACH ROWUPDATE course SET StudentNum = StudentNum +1 WHERE CourseCode=new.CourseCode;例如:在courseenroll表上建立触发器,当添加新的选课记录时,自动修改course表中的选课人数。例子:当某个学生选了某一门课程之后选课表中插入一条记录将选择该课程的选课人数增加1触发器的临时表:old 表和 new 表触发器工作时自动创建和管理的两个临时表,用于记录数据变动情况。更新操作new表old表Insert存新增的记录-Delete-存被删的记录Update存修改后的记录存修改前的记录某列的值用“new.列名”和“old.列名”表示使用图形工具创建触发器例如:在student表上创建一个触发器tri_deletestudent,当删除一条学生记录时,将该学生在courseenroll表中的选课记录全部删除。触发器名称触发时间触发事件执行的动作维护触发器修改名称触发时间触发事件执行动作( SQL代码)触发器的定义触发器是一种特殊的存储过程。当对数据库进行更新操作时被触发自动执行。不需要显式调用!InsertUpd

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论