ID: 19564969

10项目十 触发器 课件(共42张PPT)- 《网站数据库应用技术SQL Server 2008(项目教程)》同步教学(水利水电版)

日期:2025-10-30 科目: 类型:课件 查看:43次 大小:465204B 来源:二一课件通
预览图 1/12
水利水电,教学,同步,网站数据库应用技术SQL Server 2008(项目教程),项目,PPT
  • cover
(课件网) 网站数据库应用技术SQL Server 2008 (项目教程) 项目十 触发器 创建DML触发器 任务一 任务二 项目十 触发器 管理触发器 任务1 创建DML触发器 10.1.1 相关知识 触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,当对一个数据库的表进行操作时,如insert-插入新记录,delete-删除记录, update-更新记录,就会激活它执行。 触发器就像一个开关,负责灯的亮与灭,你动了开关(触发器),灯的状态改变命令(触发器要执行的命令)就会被触发。你也可以把触发器理解为多米诺骨牌倒塌前抽掉的那张骨牌。 1.SQL Server2008的触发器 触发器经常用于加强数据的完整性约束和业务规则等。SQL Server 2008中,触发器类型包括DML触发器、DDL触发器及登录触发器三种类型。 (1)DML触发器 DML( 数据操纵语言 Data Manipulation Language)触发器:是指触发器在数据库中发生DML事件时将启用。即如果用户要通过数据操作语言 (DML) 事件编辑数据,则执行 DML 触发器。DML事件即指在表或视图中修改数据的INSERT、UPDATE 或 DELETE语句。 (2)DDL触发器 DDL(数据定义语言 Data Definition Language)触发器:是指当服务器或数据库中发生DDL事件时将启用。DDL事件即对应于 Transact-SQL CREATE、ALTER 和 DROP 语句,以及执行类似 DDL 操作的某些系统存储过程。 (3)登陆触发器 登陆触发器:是在遇到 LOGON 事件时触发。LOGON 事件是在建立用户会话时引发的。其中,DML是数据库应用中最常用的触发器,本章以DML触发器作为主要学习内容。 2.DML触发器执行的临时状态 在sql server 2008中,dml触发器的实现是基于两个临时的逻辑表(deleted表和inserted表),当触发执行dmls触发器时,这两个临时表将被创建,并存在于数据库服务器的内存中,我们只有只读的权限。 deleted和insered表的结构和触发器所在的数据表的结构是一样的。当触发器执行完成后,它们也就会被自动删除。 触发器分为后触发和替代触发两种方式。后触发为执行insert、update、delete等sql命令完成之后,再执行触发器的代码,后触发器只能创建在表上,不能创建在视图上。替代触发的特征是引起触发器执行的sql语句只起到启动触发器的作用,而且实际上没有执行,取而代之的是执行触发器中的sql语句,替代触发器可以建立在表上或者视图上。 (1)insered表 inserted表存放了insert和update语句中的副本。在insert或update语句的执行中,这些新行同时被加到inserted表和trigger表中。inserted表中的行是trigger表中新行的副本。比如你想向一个表插入一条新数据记录,那么触发器执行时,就会把这条新记录插入到inserted表中备用。 (2)deleted表 deleted表存放了delete和update语句中相关行的副本。在 delete或update语句的执行中,这些相关行从trigger表中移到了deleted表中。一般情况下,这两张表中无共同行。因此, deleted表用于存放操作 update、delete语句时,触发器所在的表中即将被删除或者即将被更新替换的数据。 一个update效果上等价于一个delete再接着一个insert。首先“旧”行被复制到deleted表中,然后新行被复制到trigger表和inserted表中 3.DML触发器语法 表或视图的DML触发器创建语法: CREATE TRIGGER [schema_name.]触发器名 ON { 表|视图 } [ WITH ENCRYPTION] { FOR | AFTER | INSTEAD OF } { [ INSERT ] [ , ] [ UPDATE ] [ , ] [ DELETE ] } [ WITH APPEND ] [ NOT FOR REPLICATION ] AS [{IF UPDATE(列名)[{AND |OR} UPDATE(列名)][…n]}] SQL语句块 参数说明: WITH ENCRYPTION 对CREATE TRIGGER语句的文本进行模糊处理。使用WITH ENCR ... ...

~~ 您好,已阅读到文档的结尾了 ~~