实验八使用触发器实现数据完整性
存储过程触发器和数据完整性课件
触发器应用案例
总结词
自动、高效、保证数据一致性
详细描述
触发器是一种自动执行的数据完整性束缚机制,可以在数据库中实现数据一致性的保证。当数据库中 产生插入、更新或删除操作时,触发器会自动触发并执行相关的操作,以保证数据的一致性和完整性 。同时,触发器还可以提高数据库的性能和响应速度。
数据完整性应用案例
触发器通常用于在数据库中维护数据 完整性,通过监控对表执行的更改操 作,并采取相应的措施来确保数据的 准确性和一致性。
触发器类型
01
02
03
04
根据事件类型,触发器可以分 为插入触发器、删除触发器和
更新触发器。
插入触发器:当在表中插入新 记录时触发。
删除触发器:当从表中删除记 录时触发。
更新触发器:当修改表中记录 的数据时触发。
触发器与数据完整性
REPORTING
触发器对数据完整性的影响
触发器可以用于禁止对数据库 的非法修改,从而维护数据的 完整性。
触发器可以用于在数据修改时 自动进行一些附加操作,例如 记录日志或计算衍生值。
触发器可以用于强制执行一些 业务规则,例如检查新插入的 数据是否符合特定的条件。
如何通过触发器实现数据完整性
感谢观看
REPORTING
加灵活地实现自动化的数据处理操作。 • 在保护数据完整性和安全性方面,存储过程和触发器都可以发挥重要作用。通过使用参数化查询、束缚、校验
等机制,可以有效地防止SQL注入攻击和数据的不完整性和错误。同时,使用日志和特殊处理机制可以更好地 记录操作日志和特殊信息,以便于后期审计和故障排查。
PART 06
由用户创建,根据特定业 务需求编写,用于执行自 定义的业务逻辑。
数据库实现数据完整性
限制输入到指定列的值只能为某些特定值 语法: [CONSTRAINT 约束名] CHECK (逻辑表达式) 两种强制域完整性的方法:CHECK 约束和规则 CHECK 约束定义了一个表达式,若数据修改语句使 得表达式值为 FALSE 的话,将拒绝语句执行 规则的功能和 CHECK 约束基本相同,除了语法不同, 能力稍弱。 规则可定义一次,然后对多个列分别绑定;而 CHECK 约束则需要对每个列定义。但 CHECK 约束 的功能略强一些(例如引用同行中其他列的值和调用 系统函数等)
创建CHECK 约束
在创建SC表时定义CHECK约束 Create Table SC ( sno char(5) not null, cno char(1) not null,
列级CHECK约束
grade decimal(4,1) check(grade>=0 and grade<=100),
primary key (sno,cno));
Copyright@2008
20
创建CHECK 约束
Create Table SC ( sno char(5) not null, cno char(1) not null, grade decimal(4,1), primary key (sno,cno), check(grade>=0 and grade<=100));
CREATE TABLE sc1 ( ……….,
约束名
constraint PK_SC PRIMARY KEY(sno,cno));
Copyright@2008 13
删除和添加主键
删除表上已定义的主键
ALTER TABLE SC1 DROP CONSTRAINT PK_SC;
使用约束和触发器实现数据完整性
嵌套触发器工作方式
1 INSERT、UPDATE 或 DELETE 语句
2
触发器在另一个表上执行 INSERT、UPDATE 或 DELETE…
3 …依次继续…
递归触发器的注意事项
默认禁用 - 若要启用: • ALTER DATABASE AdventureWorks2008 SET RECURSIVE_TRIGGERS ON
键约束
主键约束:
• 每个表一个 PRIMARY KEY – 基于一列或多列
• 值必须唯一 – 不允许 NULL 值
外键约束:
CREATE TABLE [HumanResources].[Department] (… CONSTRAINT [PK_Department_DepartmentID] PRIMARY KEY CLUSTERED ([DepartmentID] ASC) WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY])
[Sales].[Customer] ([CustomerID])
其他约束
DEFAULT CHECK UNIQUE
• 定义未指定列值时应取的列值 • 每列只有一个 DEFAULT • 允许某些系统函数 • 限制可输入列的值 • 每列允许多个 CHECK 约束 • 可引用同表中的列,无子查询 • 确保列中的每个值都是唯一的 • 唯一列中只允许一个 NULL 值 • 可包含一列或多列
机制 数据类型 规则 默认值 约束 触发器
说明 定义可存储在列中的数据的类型 定义可插入列中的可接受值 定义未指定列值时应取的列值 定义数据库引擎如何强制实施数据完整性 定义在修改表时自动执行的代码
第 2 节:实现约束
• 约束 • 键约束 • 其他约束 • 级联引用完整性 • 约束检查注意事项 • 演示:创建约束
实验8 数据完整性实验
实验8 数据完整性实验(4学时)1.实验目的本实验的目的是通过实验使学生加深对数据完整性的理解,学会创建和使用触发器。
2.实验内容本实验的内容为:使用SQL设计触发器,通过SQL Server企业管理器定义它们。
1.具体完成下面例题:利用触发器来保证学生选课库中选课表的参照完整性,以维护其外码与参照表中的主码一致。
CREATE TRIGGER SC_inserted ON 选课FOR INSERTAS IF(SELECT COUNT(*)FROM 学生,inserted,课程WHERE 学生.学号= inserted.学号AND inserted.课程号= 课程.课程号)=0 ROLLBACK TRANSACTION代码:截图:2.把课件第5章中卷烟数据库及其触发器的例子在Sql server中完成。
建立卷烟库存表代码:建立卷烟库存表截图:建立卷烟销售表代码:建立卷烟销售表截图:创建触发器[T_INSERT_卷烟库存表]代码:创建触发器[T_INSERT_卷烟库存表]截图:针对[卷烟库存表],插入测试数据:创建触发器[T_INSERT_卷烟销售表]代码:输入数据3.创建一个规则,使成绩大于等于零。
并将其绑定到成绩列上。
规则代码:规则截图:绑定代码:绑定截图:4.创建一个默认值,并绑定到学分列上,使学分默认为4个学分。
默认值代码:默认值截图:绑定代码:绑定截图:5.建立一个update触发器,当更新sc表中的score列时,触发器检查成绩是否提高10%。
如果成绩超过了10%,将以ROLLBACK语句复原触发器和调用触发器语句,并打印“成绩升幅太大,更新失败!”,否则,打印“成绩更新成功!”。
代码:截图:检验:3.实验步骤1、在企业管理器中创建触发器1)在企业管理器中,由服务器开始逐步扩展到触发器所属表的数据库(本例为学生选课数据库),打开表文件夹,在表窗口中用鼠标右击触发器所属的表(本例为选课表)。
太原理工大学 数据库系统概论 实验报告 数据的完整性
本科实验报告课程名称:数据库系统原理B 实验项目:数据的完整性实验地点:专业班级:学号:学生姓名:指导教师:201 年月日一目的与要求(1)了解SQL Serer数据库系统中数据完整性控制的基本方法(2)熟练掌握常用CREATE 或ALTER 在创建或修改表时设置约束(3)了解触发器的机制和使用(4)验证数据库系统数据完整性控制二实验设备与环境使用SQL Server数据库管理系统提供的SSMS和查询编辑器三实验内容、实验记录及实验结果与分析结合ST数据库中的各个表,设置相关的约束,要求包括主键约束、外键约束、唯一约束、检查约束、非空约束等,掌握各约束的定义方法。
设置一个触发器,实现学生选课总学分的完整性控制,了解触发器的工作机制。
设计一些示例数据,验证完整性检查机制。
要求包括如下方面的内容:1.创建基本表及约束Student表Course表SC表如下图所示表创建成功:2.插入数据(1)插入学生信息到Student表(2).插入课程信息到Course表(3)插入到SC表(4)检查插入表中的数据二、检查完整性约束1.检查主键约束(1)INSERT INTO Student VALUES('','李斌','男',20,'CS','1001',0) INSERT INTO Student VALUES('','李斌','男',20,'CS','1001',0)UPDATE Student SET Sno='' WHERE Sname = '张立'无法正确运行因为:违反了PRIMARY KEY 约束'PK__Student__CA1FE4647F60ED59'。
不能在对象'dbo.Student' 中插入重复键。
在MySQL中使用触发器和存储过程实现数据完整性
在MySQL中使用触发器和存储过程实现数据完整性导语:在数据库管理系统中,保证数据的完整性是非常重要的。
当多个用户同时访问数据库时,可能会发生一些错误,如数据丢失、不一致性等。
为了避免这些问题,MySQL提供了触发器和存储过程等功能,通过在特定事件发生时自动执行一些操作,从而实现数据的完整性。
一、触发器1. 触发器定义和使用方式触发器是MySQL中的一种特殊对象,可以在数据库表上定义,并指定在特定事件(如INSERT、UPDATE、DELETE)发生时自动触发执行。
触发器可以实现对数据的验证、限制和修改等操作,从而保证数据的完整性。
触发器的创建语法如下:```mysqlCREATE TRIGGER trigger_name{BEFORE | AFTER} {INSERT | UPDATE | DELETE}ON table_nameFOR EACH ROWtrigger_stmt```其中,trigger_name指定了触发器的名称,table_name指定了触发器所在的表名,BEFORE和AFTER指定了触发器的执行顺序,INSERT、UPDATE和DELETE指定了触发器所监听的事件,FOR EACH ROW表示触发器对每一行数据都会执行一次,trigger_stmt则是触发器执行的具体语句。
以下是一个简单的例子,通过触发器实现对用户表的省份字段进行验证:```mysqlCREATE TRIGGER trigger_nameBEFORE INSERT ON userFOR EACH ROWBEGINIF NEW.province NOT IN ('北京', '上海', '广州', '深圳') THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '省份必须是北京、上海、广州或深圳';END IF;END;```当插入一条用户数据时,如果省份字段的值不在指定的范围内,触发器就会抛出一个错误。
实验八(上):SQL-Server用户自定义函数和触发器
实验八(上)用户自定义函数和触发器一、实验目的1、掌握SQLServer中用户自定义函数的使用方法。
2、掌握SQL Server中触发器的使用方法。
二、实验内容和要求1.创建一个返回标量值的用户定义函数RectangleArea:输入矩形的长和宽就能计算矩形的面积。
自选2种实例调用该函数。
create function RectangleArea(@a int,@b int)returns intasbeginreturn @a*@benddeclare @area intexecute @area=RectangleArea 3,5print('矩形面积是:')print @areadeclare @area intexecute @area=RectangleArea 7,8print('矩形面积是:')print @area2.创建一个用户自定义函数(内嵌表值函数),功能为产生某个系的学生选修信息,内容为学号,姓名,课程名,成绩。
调用这个函数,显示信息系有选课学生的信息。
create function Search (@sdept char(10))returns tableasreturn(select sc.sno 学号,student.sname 姓名,ame 课程名,sc.grade 成绩,student.sdept 系别from sc,student,course where o=o andsc.sno = student.sno and sdept=@sdept)select*from Search('cs')3.创建一个作用在P表上的触发器P_checks,确保用户在插入或更新P表的WEIGHT值时,所提供的WEIGHT值介于20与40之间,否则给出错误提示并回滚此操作。
请测试该触发器,测试方法自定。
create trigger P_checks on p for insertasbegindeclare @weight intselect @weight=weight from insertedif @weight<10 or @weight>20beginRAISERROR('weight 必须在~20之间!',16,1)ROLLBACK TRANSACTIONendendinsert into p(pno,pname,color,weight)values('p7','刀片','红',40)insert into p(pno,pname,color,weight)values('p7','刀片','红',15)select*from p4.创建一个作用在J表上的触发器J_Update,禁止同时修改项目的名称和所在城市,并进行相应的错误提示。
数据库原理实验报告-数据库的完整性
实验题目四、数据库的完整性一、实验目的1、掌握使用约束实现数据完整性的方法;2、掌握使用触发器实现数据完整性的方法;二、实验内容和要求1、设置主键约束、外键约束、唯一约束、非空约束、CHECK约束等;2、使用图形用户界面创建触发器、使用SQL语言创建触发器,实现完整性控制;三、实验主要仪器设备和材料1.计算机及操作系统:PC机,Windows 2000/XP或更高版本;2.数据库管理系统:SQL Server 2005或更高版本;四、实验方法、步骤及结果测试(一)、根据实验一中的基本表,使用约束创建数据完整性。
要求:1、删除teaching中的基本表。
按实验一中的各表的定义,重新创建student表、course1)创建各基本表的先后顺序有什么影响?2)在创建各表过程中,遇到了什么问题,是如何解决的?3、通过“ALERT TABLE”语句,完成下列操作:1)为student表的sname列添加唯一约束,并命名。
2)删除course表的非空约束。
3)为sc表的score列添加约束,取值范围为[0,100]。
4)定义域title_domain,取值为{助教,讲师,副教授,教师},检查SQL Server是否3、检查student表sname列的唯一约束插入新的数据记录对新建的唯一约束进行检查,写出相应的SQL语句,并将检查的执4、检查sc表score列的CHECK约束插入不在定义范围的数据记录检查约束。
写出相应的SQL语句,并将检查执行结果截(二)、通过图形用户界面的方式创建各类约束,定义数据的完整性1、删除sc表的外键约束。
在表设计器中,单击工具栏中的“表和索引属性”按钮,打开2、删除speciality的spname字段唯一约束。
然后在表设计器中,单击工具栏中的“表和3、在表设计器中,单击工具栏中的“表和索引属性”按钮,打开“属性”对话框,在“CHECK 约束”选项中,为teacher表中的title列设置检查约束,定义取值范围为{助教、讲师、副(三)、使用触发器实现数据的完整性1、在student表中创建触发器,实现student和sc表的级联删除。
数据库实验-完整性-索引-触发器说课讲解
数据库实验-完整性-索引-触发器实验五实验报告二、实验内容5.1 实体完整性1)在数据库School中建立表Stu_Union,进行主键约束,在没有违反实体完整性的前提下插入并更新一条记录建立表Stu_Union,进行主键约束在没有违反实体完整性的前提下插入一条记录在没有违反实体完整性的前提下更新一条记录2)演示违反实体完整性的插入操作3)演示违反实体完整性的更新操作4)演示事务的处理,包括事务的建立,处理以及出错时的事务回滚,演示事务处理和批处理的区别。
提示:SQL2005相关语句为BEGIN TRANROLLBACK TRANCOMMIT TRAN可以这样演示:新建一个包含两条语句的事务,使第一条成功而第二条失败,然后查看整个事务是否回滚。
重要提示:SQL默认只回滚出错的语句,要回滚整个事务,需要预先执行以下语句:SET XACT_ABORT ONa.先执行如下SQL语句(可执行成功)b.再执行如下语句,此时为执行第一句insert语句成功,第二句insert语句失败c.查询事物是否回滚由上可知,表为b步骤即事物出错前的状态,所以整个事物回滚。
5)通过建立Scholarship表,插入一些数据。
演示当与现有的数据环境不等时,无法建立实体完整性以及参照完整性。
提示:即演示不能为表Scholarship生成主键和外键的情况。
a.b. 不能为表Scholarship生成主键c.不能为表Scholarship生成外键5.2参照完整性1)为演示参照完整性,建立表Course,令cno为其主键,并在Stu_Union中插入数据。
为下面的实验步骤做预先准备。
在Stu_Union中插入数据建立表Course,令cno为其主键2)建立表sc,另sno和cno分别为参照Stu_Union表以及Course表的外键,设定为级连删除,并令(sno, cno)为其主键。
在不违反参照完整性的前提下,插入数据。
3)演示违反参照完整性的插入数据4)在Stu_Union中删除数据,演示级连删除。
在SQLServer使用触发器实现数据完整性
在SQLServer使用触发器实现数据完整性作者:陈潇来源:《电脑知识与技术》2013年第35期摘要:在SQLServer数据库中,数据的安全行和完整性是实现有效数据利用的前提条件。
该文主要介绍了触发器的原理、工作机制、与约束的区别,以及创建触发器的实例。
关键词:SQLServer;触发器;数据完整性中图分类号:TP391 文献标识码:A 文章编号:1009-3044(2013)35-7895-02In SQLServer Data Integrity Using TriggersCHEN Xiao———————(Xuzhou, Jiangsu Joint Vocational and Technical College of Information Technology,Finance Branch, Xuzhou 221008,China)Abstract: In SQLServer databases, data security and integrity of the line is to achieve a prerequisite for effective data utilization. This paper describes the principles of the trigger, working mechanism, and constraint distinction, and create triggers instance.Key words: SQL Server;trigger; data integrity1 实现数据完整性的手段在SQLServer中,在服务器端实现数据完整性主要有两种手段:一种是在创建表时定义数据完整性,主要分为:实体完整性、域完整性、和级联参照完整性;实现的手段是创建主键约束、唯一键约束、检查约束、默认值约束和各种级联完整性约束。
另一种是通过编写触发器语句来实现,通过定义触发条件和编写触发后执行语句,来实现对数据表操作的各种约束。
实验八 数据完整性 实验指导
实验八数据完整性实验指导一、完整性的概念数据完整性是指存储在数据库中的数据正确无误,并且相关数据具有一致性。
数据库中的数据是否完整,关系到数据库系统能否真实的反映现实世界。
立足在“学生”表中学生的学号要具有唯一性,学生性别只能是男或女,其所在的系部、专业、班级必须是存在的,否则,就会出现数据库中的数据与现实不符的现象。
如果数据库中总存在不完整的数据,那么它就没有存在的必要了,因此,实现数据的完整性在数据库管理系统中十分重要。
根据数据完整性机制所作用的数据库对象和范围不同,数据完整性可分为实体完整性、域完整性、参照完整性和用户定义完整性4种类型。
1. 实体完整性实体是表中的记录,表中的一条记录就是一个实体。
实体完整性要求在表中不能存在完全相同的记录,而且每条记录都要具有一个非空且不重复的主键值。
这样,就可以保证数据所代表的任何事物都不重复、可以区分。
例如,学生表中的学号必须唯一,并且不能为空,这样就可以保证学生记录的唯一性。
实现实体完整性的方法主要有主键约束、唯一索引、唯一约束和制定IDENTITIY属性。
2. 域完整性域完整性是指特定列的项的有效性。
域完整性要求向表中指定列输入的数据必须具有正确数据类型、格式及有效的数据范围。
例如,假设现实中学生的成绩为百分制,则在“课程注册”表中,向成绩列输入的数据,不能出现字符,也不能是小于0或大于100的数值。
实现域完整性的方法主要有CHECK约束、外键约束、默认约束、非空约束、规则及在建表时设置的数据类型。
3. 参照完整性参照完整性是指在有关联的两个或两个以上的表中,通过使用主键和外键或唯一键和外键之间的关系,使表中的键值在相关表中保持一致。
引用完整性要求不能引用不存在的值。
如果一个键值发生更改,则在整个数据库中,对该键值和所有引用要进行一致性的更改。
例如,在学生表中的“班级代码”列的值必须是在班级表中“班级代码”列中存在的值,防止在录入学生记录时将学生分配到一个不存在的班级中。
数据完整性和一致性控制约束规则触发器事务锁王.ppt
图 6 | 13 输 入 默 认 值
注意:单引号不需要输入,在表保存后,在单引号外还会自动生成一 对小括号。
(3)关闭“表设计器”窗口。
8.1.2 使用约束实施数据完整性控制
1.约束的建立 (4)默认约束的创建 —使用Transact-SQL语句
【格式】 ALTER TABLE table_name ADD CONSTRAINT constraint_name DEFAULT constant_expression FOR column_name
8.1.1 数据完整性概述
1.完整性的概念
数据完整性是指数据的正确性、有效性、一致性和相容性。由于数据 库是一个动态的集合,数据不断地被插入和被修改,因此由于主观或 客观的原因,可能破坏数据库的数据完整性 。
2.破坏数据库的数据完整性的情况
(1)无效的数据被添加到数据库中。如:某在教师管理系统中,输 入的教师号不存在 。
USE CollegeMIS GO ALTER TABLE Student ADD CONSTRAINT CK_Birthday CHECK (Birthday<=GetDate()) GO
8.1.2 使用约束实施数据完整性控制
1.约束的建立
(4)默认约束的创建 ——使用对象资源管理器
在用户输入某些数据时,希望一些数据在没有特例的情况下被自动输入, 例如,学生的注册日期应该是数据录入的当天日期;学生的修学年限是固定的 值;学生性别默认是“男”等情况,这个时候需要对数据表创建默认约束。 下面分别用例子说明如何在对象资源管理器中和利用SQL语句创建默认约束
【例8-7】为CollegeMIS数据库中的Student表的Grade字段创建一个默认约 束,约束名为DF_Grade,默认值为1。
在MySQL中使用触发器实现数据校验
在MySQL中使用触发器实现数据校验数据库是现代应用程序中不可或缺的一部分,它用于存储、管理和操作大量的数据。
在处理数据时,确保数据的准确性和完整性非常重要。
MySQL是目前最流行的关系型数据库之一,它提供了丰富的功能和强大的性能。
在使用MySQL进行数据操作时,我们经常需要对数据进行校验,以确保数据的正确性。
这种数据校验可以使用触发器来实现。
触发器是MySQL中一种特殊的存储过程,它可以在特定的数据库操作触发时自动执行特定的逻辑。
下面,我们将探讨如何使用触发器在MySQL中实现数据校验。
1. 引言在开始讨论使用触发器实现数据校验之前,我们先了解一下何为数据校验。
数据校验是指对数据库中的数据进行验证和验证,以确保数据的完整性和正确性。
它可以通过各种手段来实现,如约束、触发器、存储过程等。
触发器是一种特殊的存储过程,与表关联,并在插入、更新或删除表中的数据时自动触发。
通过在触发器中编写逻辑代码,我们可以在数据库操作之前或之后执行特定的数据校验逻辑。
2. MySQL触发器的工作原理在了解如何使用触发器实现数据校验之前,我们先来了解一下MySQL触发器的工作原理。
MySQL触发器由四个主要的元素组成:事件、时机、触发器函数和触发器执行语句。
其中,事件指的是对表的操作,如插入、更新或删除;时机指的是触发器的执行时间,可以是事件之前(BEFORE)或事件之后(AFTER);触发器函数是编写的带有逻辑的存储过程;触发器执行语句是在触发器函数中执行的SQL语句。
当一个事件发生时,如果其满足触发器的条件,MySQL会自动执行对应的触发器函数,并在函数中执行相关的SQL语句。
3. 使用触发器实现插入数据的校验在实现数据校验时,最常见的场景之一是在插入数据时进行校验。
下面是一个示例,演示如何使用触发器在MySQL中实现插入数据的校验。
假设我们有一个名为"students"的表,其中包含"student_id"和"student_name"两个字段。
如何使用触发器实现数据审计和日志记录
如何使用触发器实现数据审计和日志记录引言:在现代数据驱动的社会中,保护数据的完整性和可追溯性是至关重要的。
为了实现这些目标,许多组织都会使用数据审计和日志记录的方法。
本文将介绍如何使用触发器来实现数据审计和日志记录,解释触发器的工作原理及其在数据库系统中的应用。
一、什么是触发器触发器(Trigger)是数据库管理系统(DBMS)中的一种特殊对象,它可以在指定的数据库事件发生时自动执行一系列的操作。
这些事件可以是数据插入、更新或删除,触发器可以在这些事件发生时对数据执行额外的操作。
二、为什么使用触发器实现数据审计和日志记录1. 数据审计:数据审计是指对数据库中的操作进行跟踪和记录,以保护数据的完整性和追踪数据操作的来源。
通过使用触发器,可以在数据被插入、更新或删除时记录相关操作,为后续审计与溯源提供可靠的依据。
2. 日志记录:日志记录是指将数据库中的操作记录下来,以便在出现故障或错误时进行恢复和故障排查。
触发器可以用于在事务执行期间记录相关操作,生成详细的日志信息,形成完整的操作记录。
三、如何实现数据审计和日志记录在实际应用中,使用触发器实现数据审计和日志记录需要以下几个步骤:1. 创建触发器:首先,需要根据需要创建相应的触发器。
触发器包括触发事件(包括插入、更新或删除)、触发时间(在事务之前或之后)、触发过程(要执行的操作)。
创建触发器时,需要明确指定触发时机和执行的操作。
2. 设置触发条件:触发器可以根据特定的条件来触发执行。
例如,可以设置只有当特定数据满足某种条件时触发器才会执行操作。
设置触发条件可以进一步细化日志记录和数据审计的范围,提高效率。
3. 记录操作信息:在触发器中,可以通过访问系统提供的预定义函数和变量来获取相关的操作信息。
例如,可以获取当前操作的用户、操作时间、操作类型等信息,并将这些信息记录下来。
这样,在后续的审计和日志分析中就可以准确地追溯操作来源。
4. 存储操作记录:触发器在执行操作后,需要将相关的操作记录存储到特定的表或文件中。
实验八 使用触发器实现数据完整性
实验八使用触发器实现数据完整性
一、实验目的
使学生用触发器实现数据完整性的重要性,掌握用触发器实现数据完整性的方法,掌握用触发器实现参照完整性的方法,并理解触发器与约束的不同。
二、实验内容
(1)为表建立触发器,实现域完整性,并激活触发器进行验证。
(2)为表建立级联的触发器,实现参照完整性,并激活触发器进行验证
(3)比较约束与触发器的执行顺序。
三、实验指导
实验8.1创建JXGL数据库的表S的INSERT触发器材tri_INSERT_S,插入年龄在线15到30之间的记录。
实验8.2 创建JXGL数据库的表S 的DELETE 触发器tgr_s_delete,当删除S表中的记录时触发该触发器
DELETE 触发器会在删除数据的时候主,将刚才删除的数据保存在DELETED 表中。
下面删除表S 中的记录:
实验8.3 在数据库JXGL中有3 个表,即S、SC和C,其中,表SC的字段sno作为外键与表S连接。
如果要删除表S中的记录,需要创建触发器,先删除SC中与要删除记录级联的所有记录,再删除表S中的记录。
实验8.4 为学生表S创建一个UPDATE 触发器,当更新了某同学的姓名时,就激活该触发器,并使用PRINT 语句返回一个提示信息。
UPDATE 触发器会在更新数据后,将更新前的数据保存在deleted表中,将更新后的数据保存在inserted 表中。
实验8.5 触发器中的其它操作。
(1)触发器中常用的消息函数raiserror()的应用。
(2)禁用、启用触发器。
(3)查询创建的触发器的信息。
(4)查看触发器的触发事件。
(5)查看创建触发器信息语句。
触发器与数据库完整性控制
触发器与数据库完整性控制【摘要】触发器(Trigger)是用户定义在关系表上的一类由事件驱动的特殊过程。
一旦定义,任何用户对表的增、删、改操作均由服务器自动激活相应的触发器,在DBMS核心层进行集中的完整性控制。
触发器类似于约束,但是比约束更加灵活,可以实施比FOREIGN KEY约束、CHECK约束更为复杂的检查和操作,具有更精细和更强大的数据控制能力。
【关键词】SQL触发器,数据库完整性一、绪论数据库的完整性是为了保证数据库中存储的数据是正确的。
所谓正确是指符合现实世界的语义。
实体完整性总应在最低级别上通过索引进行强制,这些索引或是PRIMARY KEY 和UNIQUE 约束的一部分,或是在约束之外独立创建的。
假设功能可以满足应用程序的功能需求,域完整性应通过CHECK 约束进行强制,引用完整性(RI) 则应通过FOREIGN KEY 约束进行强制。
而当约束所支持的功能无法满足应用程序的功能要求时,触发器就极为有用。
例如:CH ECK 约束只能根据逻辑表达式或同一表中的另一列来验证列值。
如果应用程序要求根据另一个表中的列验证列值,则必须使用触发器;约束只能通过标准的系统错误信息传递错误信息。
如果应用程序要求使用(或能从中获益)自定义信息和较为复杂的错误处理,则必须使用触发器;触发器也可以评估数据修改前后的表状态,并根据其差异采取对策;一个表中的多个同类触发器(INSERT、UPDATE 或DELETE)允许采取多个不同的对策以响应同一个修改语句。
二、SQL触发器语法1.定义触发器CREATE TRIGGER <触发器名>(创建表的用户才可以创建触发器,名称唯一且与<表名>在同一模式下){BEFORE|AFTER} <触发事件> ON <表名>(当这个表的数据发生变化时激活触发事件)FOR EACH {ROW|STATEMENT}(即定义行级触发器或语句级触发器)[WHEN <触发条件>](触发器激活时,只有当触发条件为真时触发动作体才执行)<触发动作体>(既可以是一个匿名PL/SQL过程块,也可以是对已创建的存储过程的调用)2.删除触发器DROP TRIGGER <触发器名> ON <表名> (触发器必须是一个已经创建的触发器,并且只能由具有相应权限的用户删除)三、SQL触发器在保持数据库完整性中的实际应用在触发器的应用中,我们通常会用到两个特殊的表:inserted表和deleted表。
完整性与触发器
添加FOREIGN KEY约束
• 实现引用完整性。 • 外码所引用的列必须是有PRIMARY KEY约束或 UNIQUE约束的列。 • 添加FOREIGN KEY约束的语法格式为: ALTER TABLE 表名 ADD [ CONSTRAINT 约束名] FOREIGN <列名>) REFERENCES 引用表名(<列名>)
触发器
• 触发器是用编程的方法实现复杂的 商业规则,它可以实现一般的数据 完整性约束实现不了的复杂的完整 性约束。
事务
• 事务(Transaction)是作为完整的工 作单元执行的一系列操作。 • 如果一个事务中的所有操作都成功, 则事务成功,其对数据库的更改都会 成为永久性的更改。 • 如果事务中的任何一个操作失败,则 整个事务失败,其中所完成的操作均 被取消,所有对数据的更改均无效。
• 语法格式为: DROP TRIGGER 触发器名 [ , ... n] • 例:删除tri_grade触发器。 DROP TRIGGER tri_grade
练习
• 实现限制多列取值范围约束的触发器。实 现限制最低工资必须小于最高工资. • 实现创建多个表之间列取值约束的触发器. 限制雇员的工资必须在工作表的相应的最 低工资和最高工资之间.
CHECK约束
• 例1.限制雇员的工资必须大于等于200。 ALTER TABLE 雇员 ADD CONSTRAINT CHK_Salary CHECK ( 工资 >= 200 ) • 例2.限制工资表的最低工资小于等于最高 工资。 ALTER TABLE 工作 ADD CONSTRAINT CHK_Job_Salary CHECK( 最低工资 <= 最高工资 )
例题
用触发器实现数据库的完整性
导 致 要 加 到 该 触 发 器 表 中 去 的任 何 新 行 。 在 执 行 I S R 或 NE T ⑦ 可以使用 WIHE C Y T N 子句对触发器进行加密 。 T N R P I O U D ' 操 作 时 . 的行 同 时添 加 到 触 发 器 表 和 I S R D 表 P 【 E 新 NET E 旦 进行 加 密 . 发 器 的定 义 即 不 能再 行 解 密 . 何 人 都 无 法 进 触 任 中 ,N E T D 表 中 的行 总 是 与触 发 器 表 中 的 新 行 相 同 。 ISR E 行查 看 。 括触 发 器 的所 有 者 和 系统 管 理 员 。 包 D L T D 表: 放 由 D 咖 E E E 存 E 或 U D T 语 句 的 执 行 而 PA E ⑧ 触发器不应该 返回结果集 。 导 致 要 从 被 该 触 发 器 表 中删 除 的所 有 行 。在 执 行 I S R 或 4 用触 发器 实 现 数据 完整 性 的应 用 实 例 NE T U D T 操 作 时 . 删 除 的 行 从 激 活 的 触 发 器 表 中 被 移 到 PA E 被 以 下 操 作 基 于 . 表 : 生 表 S U E T( 号 S O 姓 名 2张 学 TDN 学 N 。 D L T D 表 。 两 个 表 不 会有 共 同 的行 。 E E E 这 S A E性 别 S X年 龄 S G N M ' E 。 A E) 当用 户 对 指 定 的 表 进 行 插 入 数 据 操 作 时 。 N E T 触 发 器 IS R 成 绩表 C U S ( 号 S O课 程 号 C O, 绩 S O E O R E ̄ N , N 成 C R) 触发执行。 触发器检 I S R D表中的数据。 NET E 以确定该触 发器 的 f A T R IS R 1 F E E T触 发 器 ) N 当 要 求 插入 到 学 生 表 (T D N ) 的学 生 的 年 龄 要 大 于 SU ET 中 操 作是 否 应 该 执 行 和 如 何执 行 如 果 在 数 据 检 查 中发 现 有 非 法 数 据输 入 , 将 删 除指 定 的作 用 表 中 已插 入 的新 行 . 指 定 作 1 系统 使 5时 . 们 可 以创 建 一 个 I S R 我 N E T触发 器 。 输 入 的 数 据 不满 足 当 用 表 恢 复到 数 据 插 入 前 的 状 况 . 通 知 用 户 本 次 插 入 操 作 失 败 。 要 求 时 屏 幕 上能 够提 示 错 误 消 息 。 并 CR AT R G E E T I GER T  ̄ T D1 R S U ON T EN S UD T 数 据 插 入 操 作 的全 过 程 都 记 录 到 事 务 日志 文 件 中。以备 数 据 库 AF ER I S RT r N E 恢复使用。 AS 对 于 D 【 E 触 发 器 通 常 用 于 两 种 情 况 .第 一 种 情 况 防 止 E 【 DE L E @AG NT C AR EI S L T@A - AGE E EC GE S 那 些 确 实 需 要 删 除 但 会 引 起 数 据 一 致 性 问 题 的 记 录数 据 的 删 F M I E E D RO NS RT 除 : 二 种 情 况 是 执 行 可删 除 主 记 录 的子 记 录 的相 关 删 除 操 作 。 第 I @AG <1 F E 5 当 用 户 对 指 定 的 表 进 行 删 除 操 作 时 .E T 触 发 器 就 触 发 执 D LE E BE I GN RO L AC A N AC ON L B K TR S TI 行 。如果 发现 被 删 除 的数 据 与其 它表 中的 数 据 有 逻 辑 关联 。 将 则 a  ̄E, O ( AS P R R 年龄必须大于 l l , ) 5岁 6l 0 D L T D 表 中 的数 据 , 入 到 被 指 定 的 作 用 表 中 。 E EE 插 即恢 复 到 数 E ND 据 删 除前 的状 态 。并 通 知用 户 本 次 删 除 操 作 失败 ; 者 根 据设 计 或 G O f: 第 15页 ) ]转 7
SQLSever2005中利用触发器实现数据库完整性的教学案例设计-精品文档
SQL Sever2005 中利用触发器实现数据库完整性的教学案例设计数据库的完整性是指防止不合语义的即不正确、不相容的数据进入数据库[1]。
绝大部分RDBM都支持使用触发器实现数据库的完整性。
触发器( Trigger )是保证数据完整性的一种方法,是用户定义在基本表上的一类由事件驱动的特殊过程。
它与表格紧密相连,可以看做是表格定义的一部分,当用户修改指定表中的数据时,触发器将会自动执行[2] 。
触发器基于一个表创建,但是可以针对多个表进行操作,所以触发器常被用来实现复杂的商业规则。
1案例描述在银行的自动取款机系统中,有两个数据表:账户信息表(Ba nk)和交易信息表(Tran si nfo )。
账户信息表(ba nk)中记录每个账户的账号cardID 、账户的户主姓名customerName、该账户上目前的余额currentMoney 。
交易信息表( transinfo ) 中记录每一笔交易的时间transDate 、交易的卡号cardID 、交易的类型transType 、交易的金额transMoney 。
提出问题:现在余萧萧使用自动取款机系统取200元钱,如何编写程序使该自动取款机系统自动修改余萧萧的余额。
2案例分析当客户进行一项存款或取款操作时,会在交易信息表Transinfo )上形成一个插入操作。
可以利用这个插入操作的数据实现在账户信息表( Bank) 中自动修改余萧萧的余额。
3案例实现根据案例要求,引导学生进行讨论并完成触发器的设计。
具体参考操作步骤如下:Step 1:根据案例要求和以前的知识积累,学生完成数据库、数据表的创建。
Step 2:根据案例描述,在交易信息表( Transinfo )上创建一个Insert 类型的触发器trig_transInfo 。
代码如下:Step 3:可以通过在交易信息表( Transinfo )中插入一条记录模拟用户的一次取款操作来查看触发器是否被激发执行了。
数据库 完整性与触发器
• 不需要由用户调用执行,而是当用户对表中的数 据进行UPDATE、INSERT或DELETE操作时自动 触发执行的。 • 触发器通常用于保证业务规则和数据完整性,其 主要优点是用户可以用编程的方法来实现复杂的 处理逻辑和商业规则,增强了数据完整性约束的 功能。
• 完成比CHECK约束更复杂的数据约束。
例题
• 创建限制最低工资必须大于等于400的触发器。 CREATE TRIGGER tri_job_salary1 ON 工作表 FOR INSERT, UPDATE AS IF EXISTS( SELECT * FROM INSERTED WHERE 最低工资 < 400 ) BEGIN PRINT '最低工资必须大于等于400' ROLLBACK END
• DELETED表存储DELETE和UPDATE语句所影响的行的 副本。 • INSERTED表存储INSERT和UPDATE语句所影响的行 的副本。 • 这两张表是在用户执行数据的增、删、改操作时, 由SQL SERVER自动创建和管理,驻留在内存。这 两张表结构与触发器作用的表的结构相同,并且 只可以被触发器使用。 • 触发器结束时,系统自动释放这两个表的空间。 • 在触发器中可以对这两张表查询,但不可直接对 这两张表中的数据进行更改。
思考
• 执行哪些语句可以触发该出发器。 • 执行insert 学生 values(‘101998’,‘何雨 洁’,‘女’,12,‘建筑系’)的结果?该元组能插入吗?
例题
• 限制删除SC表中成绩不及格学生的修课记录。 CREATE TRIGGER tri_del_grade ON SC FOR DELETE AS IF EXISTS(SELECT * FROM DELETED WHERE Grade < 60) ROLLBACK
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验八使用触发器实现数据完整性
一、实验目的
使学生用触发器实现数据完整性的重要性,掌握用触发器实现数据完整性的方法,
掌握用触发器实现参照完整性的方法,并理解触发器与约束的不同。
二、实验内容
(1)为表建立触发器,实现域完整性,并激活触发器进行验证。
(2)为表建立级联的触发器,实现参照完整性,并激活触发器进行验证
(3)比较约束与触发器的执行顺序。
三、实验指导
实验 8.1 创建 JXGL数据库的表 S 的 INSERT触发器材 tri_INSERT_S,插入年龄在线 15 到 30 之间的记录。
实验 8.2 创建 JXGL 数据库的表 S 的 DELETE 触发器 tgr_s_delete, 当删除 S 表中的记录时触发该触发器
DELETE 触发器会在删除数据的时候主,将刚才删除的数据保存在
下面删除表S 中的记录:
DELETED表中。
实验 8.3 在数据库 JXGL中有 3 个表,即 S、SC和 C,其中,表 S 连接。
如果要删除表 S 中的记录,需要创建触发器,先删除
SC的字段 sno 作为外键与表SC中与要删除记录级联的所
有记录,再删除表S 中的记录。
实验 8.4 为学生表 S创建一个 UPDATE 触发器,当更新了某同学的姓名时,就激活该触发器,并使用 PRINT 语句返回一个提示信息。
deleted表中,将更新后的数据保UPDATE 触发器会在更新数据后,将更新前的数据保存在
存在 inserted 表中。
实验 8.5触发器中的其它操作。
(1)触发器中常用的消息函数raiserror() 的应用。
(2)禁用、启用触发器。
(3)查询创建的触发器的信息。
(4)查看触发器的触发事件。
(5)查看创建触发器信息语句。