触发器与数据库完整性控制
《数据库技术与应用》第5章 习题答案

第5章数据库完整性与安全性1. 什么是数据库的完整性?什么是数据库的安全性?两者之间有什么区别和联系?解:数据库的完整性是指数据库中数据的正确性、有效性和相容性,其目的是防止不符合语义、不正确的数据进入数据库,从而来保证数据库系统能够真实的反映客观现实世界。
数据库安全性是指保护数据库,防止因用户非法使用数据库造成数据泄露、更改或破坏。
数据的完整性和安全性是两个不同的概念,但是有一定的联系:前者是为了防止数据库中存在不符合语义的数据,防止错误信息的输入和输出,即所谓垃圾进垃圾出所造成的无效操作和错误结果。
后者是保护数据库防止恶意的破坏和非法的存取。
也就是说,安全性措施的防范对象是非法用户和非法操作,完整性措施的防范对象是不合语义的数据.2。
什么是数据库的完整性约束条件?完整性约束条件可以分为哪几类?解:完整性约束条件是指数据库中的数据应该满足的语义约束条件。
一般可以分为六类:静态列级约束、静态元组约束、静态关系约束、动态列级约束、动态元组约束、动态关系约束.静态列级约束是对一个列的取值域的说明,包括以下几个方面:①数据类型的约束,包括数据的类型、长度、单位、精度等;②对数据格式的约束;③对取值范围或取值集合的约束;④对空值的约束;⑤其他约束.静态元组约束就是规定组成一个元组的各个列之间的约束关系,静态元组约束只局限在单个元组上。
静态关系约束是在一个关系的各个元组之间或者若干关系之间常常存在各种联系或约束。
常见的静态关系约束有:①实体完整性约束;②参照完整性约束;③函数依赖约束.动态列级约束是修改列定义或列值时应满足的约束条件,包括下面两方面:①修改列定义时的约束;②修改列值时的约束。
动态元组约束是指修改某个元组的值时需要参照其旧值,并且新旧值之间需要满足某种约束条件.动态关系约束是加在关系变化前后状态上的限制条件,例如事务一致性、原子性等约束条件。
3. 试述DBMS如何实现完整性控制.解:为了维护数据库的完整性,DBMS提供了以下三种机制:①完整性约束条件定义完整性约束条件也称为完整性规则,是数据库中的数据必须满足的语义约束条件.SQL标准使用了一系列概念来描述完整性,包括关系模型的实体完整性、参照完整性和用户定义完整性。
数据库中数据完整性的维护与检验

数据库中数据完整性的维护与检验数据库是用来存储和组织大量数据的集合,它在现代信息化时代扮演着至关重要的角色。
而数据完整性是数据库管理中非常关键的一个方面,它指的是数据库中数据的准确性、一致性和有效性。
本文将探讨数据库中数据完整性的维护与检验方法,以确保数据库中数据的高度完整性。
在数据库中,数据完整性的维护是确保数据不受破坏、不受无效数据影响的重要手段。
首先,数据完整性需要确保数据库中的数据被正确地添加、更新和删除。
数据库管理系统(DBMS)通过约束来确保数据的完整性,其中包括以下几个主要的数据完整性规则:1. 实体完整性:每个表都应该有一个主键,并且此主键值不能为空。
这样可以保证在表中的每行数据都能够被唯一地标识和访问。
2. 参照完整性:参照完整性是指确保数据库中的外键与相关联的主键保持一致。
当涉及到多个表的关联查询时,参照完整性能够确保数据的一致性和准确性。
3. 域完整性:域完整性约束确保每个属性或列的取值满足特定的约束条件,例如数据类型、长度、范围或枚举值等。
这样可以防止非法或无效的数据进入数据库。
4. 用户定义的完整性:用户可以根据自己的需求定义特定的完整性规则。
通过定义触发器(trigger)、存储过程(stored procedure)或自定义函数(user-defined function),可以实现个性化的完整性约束。
除了数据完整性的维护,还需要对数据库的完整性进行检验以确保数据库中的数据的正确性。
数据库管理员可以采用以下方法来进行数据完整性的检验和校验:1. 合理的数据录入验证:在数据库中,为了提高数据的完整性,应该通过设置输入验证来限制用户输入的数据。
可以使用正则表达式、数据格式验证或输入的范围限制等方式,确保输入数据的合理性和准确性。
2. 定期进行数据备份:数据库管理员应制定定期的数据备份策略,并保障备份数据的安全性。
备份数据是数据完整性检验和恢复的一种重要手段,可确保在发生数据丢失时能够迅速恢复和修复数据库。
第7章 数据库的安全与保护

7.1.3 SQL Server的安全性控制
7.1.3.2设置身份验证模式 具体的过程如下:
在SQL Server Management Studio的【对象资源管 理器】中,右键单击服务器,在弹出的快捷菜单中 单击【属性】。 在“安全性“页上的“服务器身份验证”下,选择 新的服务器身份验证模式,再单击【确定】。 重新启动 SQL Server,使设置生效。
7.2.4 SQL Server的完整性控制
SQL Server 2008中数据完整性可分为四 种类型:
实体完整性 域完整性 引用完整性 用户定义完整性
1.实体完整性 实体完整性相关的约束如下:
PRIMARY KEY约束 UNIQUE 约束 IDENTITY属性
2.域完整性
域完整性是指给定列的输入正确性与有效性。SQL Server 2008中强制域有效性的方法有:
7.4.2 数据库恢复的基本原理 及其实现技术
3.登记日志文件(Logging) (1)以记录为单位的日志文件 (2)以数据块为单位的日志文件
7.4.2 数据库恢复的基本原理 及其实现技术
4.日志文件的作用
(1)事务故障恢复和系统故障恢复必须用日志文 件。 (2)在动态转储方式中必须建立日志文件,后备 副本和日志文件综合起来才能有效地恢复数据库。 (3)在静态转储方式中,也可以建立日志文件。 当数据库毁坏后可重新装入后援副本把数据库恢复 到转储结束时刻的正确状态,然后利用日志文件, 把已完成的事务进行重做处理,对故障发生时尚未 完成的事务进行撤销处理。
7.2.2 完整性约束条件
六类完整型约束条件分别为:
静态列级约束。 静态元组约束。 静态关系约束。 动态列级约束。 动态元组约束。 动态关系约束。
数据库应用基础第八章触发器

AS
指定对标内某字段作增加
或修改操作时触发器材起
作用
IF UPDATE(column_name)
[{and|or} UPDATE(column_name)…]
sql_statesments
定义触发器被触
发后,将执行的 数据库操作
13
8.2.1 INSERT触发器
例:在pubs库的authors表上创建 my_trigger1触发器,该触发器被操 作INSERT所触发
35
36
2. 使用系统表 例:用系统表sysobjects查看数据 库pubs上的所有触发器的相关信息
USE pubs SELECT name from sysobjects WHERE type='TR' go
37
8.3使用触发器
8.3.1 使用触发器强制数据完整性 约束和触发器都可以用来实施数据 完整性,但两者各有优势
33
还可使用系统存储过程 sp_helptrigger来查看某特定 表上存在的触发器的某些信息
EXEC sp_helptrigger <tablename>
34
例:用系统存储过程sp_helptrigger 查看表authors上存在的所有触发器 的相关信息
USE pubs EXEC sp_helptrigger authors go
23
IF UPDATE(au_lname) BEGIN raiserror('Unauthorized!',10,1) rollback transaction END
不使用INSTEAD OF而 是通过rollback
transaction子句恢 复原来的数据的方法 来实现字段不被修改
数据库自定义函数、存储过程和触发器

自定义函数、 第9章 自定义函数、存储过程和触发器 《 SQL Server 数据库管理与开发》
1自定义函数 概念 创建 查看 调用 修改 删除 2存储过程 3触发器 实训 小结
1 自定义函数
1.1 自定义函数的概念 1.2 创建自定义函数 1.3 查看自定义函数信息 1.4 调用自定义函数 1.5 调用自据库管理与开发》
自定义函数、 第9章 自定义函数、存储过程和触发器
自定义函数的概念 创建自定义函数 9.1 自定义函数 查看自定义函数信息 调用自定义函数 存储过程的概念 调用自定义函数 创建存储过程 9.2 存储过程 删除自定义函数 查看存储过程信息 触发器的概念 执行存储过程 创建触发器 修改存储过程 9.3 触发器 触发器使用限制 删除存储过程 修改触发器 常用系统存储过程 删除触发器 使用触发器的优点
《 SQL Server 数据库管理与开发》
自定义函数、 第9章 自定义函数、存储过程和触发器
教学提示:在数据库实际应用中, 教学提示:在数据库实际应用中,存在有带变量数据 处理需求,如某班学生信息表、 处理需求,如某班学生信息表、某老师带过的学 某班某门课不及格学生等。自定义函数、 生、某班某门课不及格学生等。自定义函数、存 储过程、触发器是由一系列的T 储过程、触发器是由一系列的T-SQL 语句组成的 子程序,用来满足更高的应用需求,可以说是SQL 子程序,用来满足更高的应用需求,可以说是SQL 程序设计的灵魂, 程序设计的灵魂,掌握和使用好它们对数据库的 开发与应用非常重要。 开发与应用非常重要。 教学要求: 教学要求: 自定义函数、存储过程、触发器的概念、用途、 自定义函数、存储过程、触发器的概念、用途、 创建方法。 创建方法。 编写简单的自定义函数、存储过程、触发器。 编写简单的自定义函数、存储过程、触发器。
Oracle触发器trigger详解

Oracle触发器trigger详解触发器相关概念及语法,供⼤家参考,具体内容如下概述本篇博⽂中主要探讨以下内容:什么是触发器触发器的应⽤场景触发器的语法触发器的类型案例数据:触发器的概念和第⼀个触发器数据库触发器是⼀个与表相关联的,存储的PL/SQL 语句。
每当⼀个特定的数据操作语句(insert update delete)在指定的表上发出时,Oracle⾃动执⾏触发器中定义的语句序列。
举个简单的例⼦:当员⼯表中新增⼀条记录后,⾃动打印“成功插⼊新员⼯”create or replace trigger insertStaffHintafter insert on xgj_testfor each rowdeclare-- local variables herebegindbms_output.put_line('新增员⼯成功');end insertStaffHint;触发器的应⽤场景复杂的安全性检查数据的确认数据库审计数据的备份和审计触发器的语法CREATE [OR REPLACE] TRIGGER trigger_name{BEFORE | AFTER }{INSERT | DELETE | UPDATE [OF column [, column …]]}[OR {INSERT | DELETE | UPDATE [OF column [, column …]]}...]ON [schema.]table_name | [schema.]view_name[REFERENCING {OLD [AS] old | NEW [AS] new| PARENT as parent}][FOR EACH ROW ][WHEN condition]PL/SQL_BLOCK | CALL procedure_name;其中:BEFORE 和AFTER指出触发器的触发时序分别为前触发和后触发⽅式,前触发是在执⾏触发事件之前触发当前所创建的触发器,后触发是在执⾏触发事件之后触发当前所创建的触发器。
数据库技术:触发器简介
——触发器简介
教学内容
什么是触发器 触发器的类型和触发操作 触发器的功能
1 什么是触发器
触发器是一种特殊的存储过程,在语言事件发生时,所设置的触发器就会 自动被执行,以进行维护数据完整性,或其他一些特殊的任务。
与一般意义上的存储过程不同,触发器可以说是当发生DML或DDL语言事件 时自动执行的存储过程。不能直接被调用,也不能传递或接受参数。
2 触✎发器的类型和触发操作
(一)类型
➢DML触发器
是一种与表紧密关联的特殊的存储过程,当数据库中发生数据操作语言 (DML)事件时将调用DML触发器。
➢DDL触发器
与DML触发器一样,DDL触发器也是通过事件来激活并执行其中的SQL语 句。但与DML触发器不同,DDL触发器是在响应数据定义语言(DDL)语句 时激发。这些语句主要是以CREATE、ALTER和DROP开头的语句。
after和instead of触发器不同
功能 适用对象 每个表或视图 可用的数量 级联引用
执行时机
执行顺序
after 触发器
表
允许每个动作有 多个触发器
instead of触发器
表和视图
每个动作(update、delete 和insert)一个触发器
没有限制
在作为级联引用完整性约束 目标的表上限制应用
声明引用动作之后
在约束处理之前,代替了触 发动作
在创建inserted表和deleted表 在inserted表和deleted表创
触发时
建之后
可以指定第一个和最后一个触 发器执行动作
不适用
2 触✎发器的类型和触发操作
(二)触发操作
➢DML触发器
在建立DML触发器时,要指定触发操作:insert、update或delete。至少 要指定一种操作,也可以同时指定多种。在同一个表中可以创建多个after 触发器,但在表或视图上,每个insert、update或delete语句最多可以定义 一个instead of触发器。
《数据库系统原理》PPT电子课件教案-第五章 数据库保护
四、用户定义的安全性措施 除了系统级的安全性措施外,Oracle还允许用户用数 据库触发器定义特殊的更复杂的用户级安全性措施。例 如,规定只能在工作时间内更新Student表,可以定义如 下触发器,其中sysdate为系统当前时间: CREATE OR REPLACE TRIGGER secure student BEFORE INSERT OR UPDATE OR DELETE ON Student BEGIN IF(TO_CHAR(sysdate,’DY’) IN(‘SAT’,’SUN’)) OR(TO_NUMBER(sysdate HH24') NOT BETWEEN 8 AND l7) THEN
常用的方法:
1)用一个用户名或者用户标识号来标明用户身份, 系统鉴别此用户是否是合法用户。 2)口令(Password)。为进一步核实用户,系统要求 用户输入口令 3)系统提供一个随机数,用户根据预先约定好的某 一过程或函数进行计算,系统根据计算结果是否正 确进一步鉴定用户身份。
2. 存取控制
(2)行级安全性 Oracle行级安全性由视图实现。用视图定义表的水 平子集,限定用户在视图上的操作,就为表的行级提供 了保护。视图上的授权与回收与表级完全相同。 例如,只允许用户U2查看Student表中信息系学生的 数据,则首先创建信息系学生视图S_ IS,然后将该视图 的SELECT权限授予U2用户。 (3)列级安全性 Oracle列级安全性可以由视图实现,也可以直接在基 本表上定义。 用视图定义表的垂直子集就可以实现列级安全性,方 法与上面类似。
Oracle对数据库对象的权限采用分散控制方式, 允许具有WITH GRANTOPTION的用户把相应权限或 其子集传递授予其他用户,但不允许循环授权,即被 授权者不能把权限再授回给授权者或其祖先, U1 U2 U3 U4 × 循环授权 Oracle把所有权限信息记录在数据字典中。当用 户进行数据库操作时,Oracle首先根据数据字典中的 权限信息,检查操作的合法性。在Oracle中,安全性 检查是任何数据库操作的第一步。
数据库概论参考答案
.数据库概论专科作业题参考答案第一章数据库系统导论一、选择1.C2.B3.C4.A5.A6.A7.C8.A9.D10.D11.B12.B13.B14.C15.D16.C17.A18.D19.C20.B21.A22.C23.A24.C25.D26.D27.B28.B29.A30.C31.A32.D33.A34.C35.A36. A37.C38.D39.A40.D41.D42.D43.C44.A45.D46.B二、填空1.数据2.数据库3.数据库的恢复4.概念模型5.逻辑独立性6.关系数据7.层次8.数据定义9.网状模型10.完整性约束11.关系数据12.E-R13.一对多14.信息三、名词解释1.信息:经过加工处理后具有一定含义的数据集合,它具有超出事实数据本身之外的价值。
2.数据:数据库中存储的基本对象,通常指描述事物的符号。
3.数据库:存储在计算机存储设备上,结构化的相关数据集合。
它不仅包括描述事物的数据本身,还包括相关事物之间的联系。
4.数据库管理系统:处理数据访问的软件系统,也就是位于用户与操作系统之间的一层对数据库进行管理的软件。
用户必须通过数据库管理系统来统一管理和控制数据库中的数据。
5.数据库系统:引进了数据库技术后的计算机系统,它能够有组织地、动态地存储大量数据,提供数据处理和数据共享机制,一般由硬件系统、软件系统、数据库和人员组成。
6.实体:客观存在并可相互区别的事物称为实体。
7.属性:实体所具有的某一特征或性质称为属性。
8.联系:在现实世界中,事物内部以及事物之间是有联系的,这些联系在信息世界中反映为两类:一类是实体内部的联系;另一类是实体之间的联系。
9.关键字:唯一地标识实体的属性集称为关键字。
10.实体型:用实体名及其属性名集合来抽象和描述同类实体,称为实体型。
11.实体集:同一类实体的集合称为实体集。
12.数据结构:数据结构是对数据静态特征的描述。
数据的静态特征包括数据的基本结构、数据间的联系13.数据操作:数据操作是指对数据动态特征的描述,包括对数据进行的操作及相关操作规则。
教案模板大学数据库触发器
课程名称:数据库原理与应用授课教师:[教师姓名]授课班级:[班级名称]授课时间:[具体日期] 第[周次]节课时:2课时一、教学目标1. 知识目标:(1)理解触发器的概念、作用和类型。
(2)掌握触发器的创建、修改和删除方法。
(3)了解触发器在数据库中的应用场景。
2. 能力目标:(1)能够根据实际需求设计触发器。
(2)能够调试和优化触发器,提高数据库性能。
(3)能够解决触发器在应用过程中遇到的问题。
二、教学内容1. 触发器概述(1)触发器的概念(2)触发器的作用(3)触发器的类型2. 触发器的创建(1)触发器的语法结构(2)触发器的参数和条件(3)触发器的实现方式3. 触发器的修改和删除(1)修改触发器的语法结构(2)删除触发器的方法4. 触发器的应用场景(1)数据完整性约束(2)数据审计(3)自动执行业务逻辑三、教学过程1. 导入新课教师简要介绍触发器的概念和作用,激发学生的学习兴趣。
2. 讲授新课(1)触发器概述教师讲解触发器的概念、作用和类型,通过实例说明触发器的实际应用。
(2)触发器的创建教师演示触发器的创建过程,讲解触发器的语法结构、参数和条件,并指导学生进行实践操作。
(3)触发器的修改和删除教师讲解触发器的修改和删除方法,通过实例说明如何优化触发器,提高数据库性能。
(4)触发器的应用场景教师讲解触发器在数据完整性约束、数据审计和自动执行业务逻辑等方面的应用,引导学生思考触发器的实际应用。
3. 课堂练习教师布置练习题,要求学生在课下完成,巩固所学知识。
4. 课堂小结教师总结本节课的重点内容,强调触发器的实际应用和注意事项。
四、教学评价1. 学生对触发器的理解程度2. 学生对触发器创建、修改和删除的掌握程度3. 学生在课堂练习中的表现4. 学生对触发器应用场景的掌握程度五、教学资源1. 教材:《数据库原理与应用》2. 参考资料:相关数据库技术网站、学术论文等3. 教学课件:触发器概述、触发器创建、修改和删除、触发器应用场景等注:本教案模板仅供参考,教师可根据实际情况进行调整。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
触发器与数据库完整性控制 【摘要】触发器(Trigger)是用户定义在关系表上的一类由事件驱动的特殊过程。一旦定义,任何用户对表的增、删、改操作均由服务器自动激活相应的触发器,在DBMS核心层进行集中的完整性控制。触发器类似于约束,但是比约束更加灵活,可以实施比FOREIGN KEY约束、CHECK约束更为复杂的检查和操作,具有更精细和更强大的数据控制能力。
【关键词】SQL触发器,数据库完整性
一、绪论 数据库的完整性是为了保证数据库中存储的数据是正确的。所谓正确是指符合现实世界的语义。实体完整性总应在最低级别上通过索引进行强制,这些索引或是 PRIMARY KEY 和 UNIQUE 约束的一部分,或是在约束之外独立创建的。假设功能可以满足应用程序的功能需求,域完整性应通过 CHECK 约束进行强制,引用完整性 (RI) 则应通过 FOREIGN KEY 约束进行强制。而当约束所支持的功能无法满足应用程序的功能要求时,触发器就极为有用。例如:CHECK 约束只能根据逻辑表达式或同一表中的另一列来验证列值。如果应用程序要求根据另一个表中的列验证列值,则必须使用触发器;约束只能通过标准的系统错误信息传递错误信息。如果应用程序要求使用(或能从中获益)自定义信息和较为复杂的错误处理,则必须使用触发器;触发器也可以评估数据修改前后的表状态,并根据其差异采取对策;一个表中的多个同类触发器(INSERT、UPDATE 或 DELETE)允许采取多个不同的对策以响应同一个修改语句。 二、SQL触发器语法 1.定义触发器 CREATE TRIGGER (创建表的用户才可以创建触发器,名称唯一且与在同一模式下)
{BEFORE|AFTER} ON (当这个表的数据发生变化时激活触发事件)
FOR EACH {ROW|STATEMENT}(即定义行级触发器或语句级触发器) [WHEN ](触发器激活时,只有当触发条件为真时触发动作体才执行)
(既可以是一个匿名PL/SQL过程块,也可以是对已创建的存储过程的调用)
2.删除触发器 DROP TRIGGER ON (触发器必须是一个已经创建的触发器,并且只能由具有相应权限的用户删除)
三、SQL触发器在保持数据库完整性中的实际应用 在触发器的应用中,我们通常会用到两个特殊的表:inserted表和deleted表。它们都是针对当前触发器的局部表。这两个表与触发器所在表的结构完全相同,而且总是存储在高速缓存中。当触发DELETE触发器后,从受影响的表中删除的行的副本将被放置到deleted表中。同理当触发INSERT触发器后,inserted表中保存的是刚被插入的数据行的一个副本。
当一个触发器执行激发另一个触发器的操作,而另一个触发器又激发第三个触发器,如此等等,这时就发生了触发器的嵌套。也就是下文中用到的嵌套触发器。DML 触发器和 DDL 触发器最多可以嵌套 32 层。
下面以BBS论坛数据库中多个关联表的操作为例,阐述触发器在保持数据完整性、一致性中的应用。
在BBS的程序设计中,我们经常会碰到对一个数据表操作的同时,还要自动对另外几个相关联的数据表进行操作,以保证各数据表之间数据的完整性与一致性。BBS论坛中常用的数据表有:
BBS_User表(存储用户信息):用于存储用户信息。字段有用户名、密码、积分、发帖数、等级ID、最后一次发帖、qq、Email、头像、注册时间等;
BBS_Type表:用于存储大版块信息。字段有版块ID、版块名称等; BBS_LanMu表:存储分论坛信息。字段有分论坛ID、名称、所属大版块ID、主题总数、回复总数、版主等;
BBS_Topic表:存储帖子信息。字段有帖子ID、标题、内容、发帖人、所属分论坛ID、回复总数、点击总数、最后一次回贴时间、回帖人等;
BBS_Reply表:存储回复信息。字段有回复内容、回复人、回复的帖子ID、回复时间等。
在BBS论坛中,触发器主要应用于以下几种情况: 当用户在分论坛里发表帖子时,对BBS_Topic表进行操作,但同时要自动对分论坛表BBS_LanMu里面的论坛主题总数增1,还要更新BBS_User表给该用户增加相应的积分,当用户积分达到一定分数时,自动更新该用户的等级ID,表示该用户已经升了一个等级。
当用户回复帖子时,对BBS_Reply表操作的同时,也需要对分论坛表BBS_LanMu里的回复总数增1、对BBS_Topic表的回复总数增1并更新该表里的最后回帖标题和时间,还要将BBS_User表里的该用户的发帖数增1、自动增加相应积分、更新最后发帖标题和时间等;
在论坛的后台管理中,管理员有时需要添加或者删除一个大版块。当我们要删除BBS_Type表一个大版块时,为了保证数据库各表中数据的完整性与一致性,要同时对BBS_LanMu表、BBS_Topic表、BBS_Reply表中相关联的数据记录一并删除。
下面将以后台管理中对论坛大版块进行删除操作时应用触发器为例来进行具体介绍。
(1) 需求分析 在一个BBS中常见的论坛结构如图: 在一个论坛中有许多个大版块,每个版块又对应多个分论坛。每个论坛又对应多个帖子,每个帖子又对应多个回复信息。因此需要4个相关联的表来存储相应的信息:BBS_Type表(存储大版块信息)、BBS_LanMu表(存储分论坛信息)、BBS_Topic表(存储帖子信息)、BBS_Reply表(存储回复信息)。BBS_Type与BBS_LanMu、BBS_LanMu与BBS_Topic、BBS_Topic与BBS_Reply之间都是一对多的关系。
当我们要删除BBS_Type表一个大版块时,为了保证数据库各表中数据的完整性与一致性,需要同时对BBS_LanMu表、BBS_Topic表、BBS_Reply表中相关联的数据记录一并删除。因为这里面存在3对一对多的关系,如果在程序中或者存储过程实现,显然是很困难也是不合理的。根据触发器的作用以及这4个表之间的关系,采用嵌套触发器来实现这个删除功能。为BBS_Type表、BBS_LanMu表、BBS_Topic表分别建立一个AFTER触发器,该触发器由DELETE事件触发。采用嵌套触发器可以在数据库里自动完成这多个表中相关记录的删除,大大简化了业务逻辑。这样即保证了数据的完整性与一致性,又保证程序设计的合理性与方便性。
(2)创建触发器 根据需求分析,为BBS_Type表、BBS_LanMu表、BBS_Topic表分别建立AFTER触发器,该触发器由DELETE事件触发。建立在这3个表之上的触发器之间是嵌套触发的关系,即BBS_Type表上的触发器触发BBS_LanMu表上的触发器,BBS_LanMu表上的触发器再触发BBS_Topic表上的触发器。本文中使用的数据库为Microsoft SQL Server 2005。要让触发器能嵌套触发必须在数据库“属性”中,将“递归触发器已启用”设置为TRUE。
1.为BBS_Type表(存储大版块信息)建立触发器DelType。该触发器功能是删除BBS_LanMu表中属于刚删除的大版块的所有分论坛信息。
CREATE trigger [DelType] on [dbo].[BBS_Type] after delete as begin declare @typeid int select @typeid=TypeID from deleted --获得要被删除的版块ID delete from dbo.BBS_LanMu where Typeid=@typeid end 2.为BBS_LanMu表(存储分论坛信息)建立触发器DelLanmu。该触发器功能是删除BBS_Topic表中属于刚删除分论坛的所有帖子信息。 CREATE trigger [DelLanmu] on [dbo].[BBS_LanMu] AFTER DELETE as BEGIN declare @lmid int select @lmid=LMID from deleted --获得要被删除的分论坛ID delete from dbo.BBS_Topic where LMID=@lmid END 3.为BBS_Topic表(存储帖子信息)建立触发器DelTopic。该触发器功能是删除BBS_Reply表中属于刚删除帖子的所有回复信息。
CREATE trigger [DelTopic] on [dbo].[BBS_Topic] after delete as BEGIN declare @tid int select @tid=TID from deleted --获得要被删除的帖子ID delete from dbo.BBS_Reply where TID=@tid END 执行过程 触发器执行过程如图:
当数据操作层对数据表BBS_Type发出DELETE一条记录的时候,触发器DelType被触发,此触发器将删除BBS_LanMu表中属于刚删除的大版块的所有分论坛信息。
当DelType触发器对数据表BBS_LanMu删除一条记录时,又触发BBS_LanMu表上的触发器DelLanmu,此触发器将删除BBS_Topic表中属于刚删除分论坛的所有帖子信息。