欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    第7章存储过程和触发器课件.ppt

    • 资源ID:1824640       资源大小:1.48MB        全文页数:58页
    • 资源格式: PPT        下载积分:16金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要16金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    第7章存储过程和触发器课件.ppt

    第7章 存储过程和触发器,存 储 过 程,触 发 器,7 . 1 存 储 过 程,使用存储过程的优点如下:(1)存储过程在服务器端运行,执行速度快。(2)存储过程执行一次后,就驻留在高速缓冲存储器,在以后的操作中,只需从高速缓冲存储器中调用已编译好的二进制代码执行,提高了系统性能。(3)使用存储过程可以完成所有数据库操作,并可通过编程方式控制对数据库信息访问的权限,确保数据库的安全。(4)自动完成需要预先执行的任务。存储过程可以在SQL Server启动时自动执行,而不必在系统启动后再进行手工操作,大大方便了用户的使用,可以自动完成一些需要预先执行的任务。,7.1.1 存储过程的类型,在SQL Server 2008中有下列几种类型的存储过程。(1)系统存储过程。系统存储过程是由SQL Server提供的存储过程,可以作为命令执行。系统存储过程定义在系统数据库master中,其前缀是“sp_”,例如,常用的显示系统对象信息的sp_help系统存储过程,为检索系统表的信息提供了方便快捷的方法。(2)扩展存储过程。扩展存储过程是指在SQL Server 2008环境之外,使用编程语言(如C+语言)创建的外部例程形成的动态链接库(DLL)。使用时,先将DLL加载到SQL Server 2008系统中,并且按照使用系统存储过程的方法执行。扩展存储过程在 SQL Server 实例地址空间中运行。但因为扩展存储过程不易撰写,而且可能会引发安全性问题,所以微软可能会在未来的SQL Server中删除这一功能,本书将不详细介绍扩展存储过程。(3)用户存储过程。在SQL Server 2008中,用户存储过程可以使用T-SQL语言编写,也可以使用CLR方式编写。在本书中,T-SQL存储过程就称为存储过程。,7.1.2 存储过程的创建与执行,1使用命令方式创建存储过程创建存储过程的语句是CREATE PROCEDURE或CREATE PROC,两者同义。语法格式:CREATE PROC | PROCEDURE 架构名. 过程名 ; 组号 /*定义过程名*/ 参数 类型架构名. 数据类型 /*定义参数的类型*/ VARYING = default OUT | OUTPUT READONLY/*定义参数的属性*/ , . WITH , . /*定义存储过程的处理方式*/ FOR REPLICATION AS ; . /*执行的操作*/ | EXTERNAL NAME 程序集名.类名.方法名 ; ,7.1.2 存储过程的创建与执行,1)命令主体CREATE PROCEDURE命令主体结构说明如下:(1)过程名:用于指定存储过程名,必须符合标识符规则,且对于数据库及所在架构必须唯一。(2);组号:为可选的整数,用于对同名的存储过程进行分组,以便使用一条DROP PROCEDURE语句就可删除一组存储过程(3)参数:为存储过程的形参,符号作为第一个字符来指定参数名称。(4)数据类型:用于指定形参的数据类型,形参可为SQL Server 2008支持的任何类型,但cursor类型只能用于OUTPUT参数,如果指定参数的数据类型为cursor,则必须同时指定VARYING和OUTPUT关键字,OUT与OUTPUT关键字意义相同。(5)VARYING:指定作为输出参数支持的结果集。,7.1.2 存储过程的创建与执行,(6)default:指定存储过程输入参数的默认值,默认值必须是常量或NULL。(7)OUTPUT:指示参数为输出参数,输出参数可以从存储过程返回信息。(8)READONLY:指定不能在存储过程的主体中更新或修改参数。(9):用于定义存储过程的处理方式。(10)FOR REPLICATION:用于说明不能在订阅服务器上执行为复制创建的存储过程,如果指定了FOR REPLICATION,则无法声明参数。(11)SQL语句:代表过程体包含的T-SQL语句,存储过程体中可以包含一条或多条T-SQL语句,除了DCL、DML与DDL命令外,还能包含过程式语句,如变量的定义与赋值、流程控制语句等。(12)EXTERNAL NAME:指定.NET Framework程序集的方法,以便CLR存储过程引用。,7.1.2 存储过程的创建与执行,2)过程选项的具体格式为: := ENCRYPTION RECOMPILE EXECUTE AS 子句 (1)ENCRYPTION:指定SQL Server对CREATE PROCEDURE语句的原始文本进行加密。对于CLR存储过程,这个选项不可用。(2)RECOMPILE:指定数据库引擎不缓存该过程的计划,该过程在运行时编译。(3)EXECUTE AS子句:指定在其中执行存储过程的安全上下文。,7.1.2 存储过程的创建与执行,3)注意事项(1)用户定义的存储过程只能在当前数据库中创建(临时存储过程除外,它总是在系统数据库tempdb中创建)。存储过程名称存储在sysobjects系统表中,而语句的文本存储在syscomments中。(2)SQL Server启动时可以自动执行一个或多个存储过程。这些存储过程必须由系统管理员在master数据库中创建,并在sysadmin固定服务器角色下作为后台过程执行。这些过程不能有任何输入参数。 (3)CREATE PROCEDURE的权限默认授予sysadmin固定服务器角色成员、db_owner 和 db_ddladmin 固定数据库角色成员。sysadmin 固定服务器角色成员和 db_owner 固定数据库角色成员可以将CREATE PROCEDURE权限转让给其他用户。,7.1.2 存储过程的创建与执行,(4)SQL语句的限制。 如下语句必须使用对象的架构名对数据库对象进行限定:CREATE TABLE、ALTER TABLE、DROP TABLE、TRUNCATE TABLE、CREATE INDEX、DROP INDEX、UPDATE STATISTICS及DBCC语句。 如下语句不能出现在CREATE PROCEDURE定义中:SETPARSEONLY、SETSHOWPLAN_TEXT、SETSHOWPLAN_XML、SETSHOWPLAN_ALL、CREATESCHEMA、CREATE FUNCTION、ALTER FUNCTION、CREATE PROCEDURE、ALTER PROCEDURE、CREATE TRIGGER、ALTER TRIGGER、CREATE VIEW、ALTER VIEW、USE 数据库名等。,7.1.2 存储过程的创建与执行,2存储过程的执行通过EXECUTE或EXEC命令可以执行一个已定义的存储过程,EXEC是EXECUTE的简写。语法格式: EXEC | EXECUTE 返回状态 = 模块名 ;组号 | 模块名变量 参数名 = 值| 变量 OUTPUT | DEFAULT , . WITH RECOMPILE ; ,7.1.2 存储过程的创建与执行,1)语句说明(1)返回状态:为可选的整型变量,保存存储过程的返回状态。EXECUTE语句使用该变量前,必须对其声明。(2)模块名:要调用的存储过程或用户定义标量函数的完全限定或者不完全限定名称。“组号”用于调用已定义的一组存储过程中的某一个。(3)模块名变量:局部定义的变量名,保存存储过程或用户定义函数的名称。(4)参数名:为CREATE PROCEDURE或CREATE FUNCTION语句中定义的参数名,“值”为实参。如果省略“参数名”,则后面的实参顺序要与定义时参数的顺序一致。(5)变量:为局部变量,用于保存OUTPUT参数返回的值。(6)DEFAULT:DEFAULT关键字表示不提供实参,而是使用对应的默认值。(7)WITH RECOMPILE:执行模块后,强制编译、使用和放弃新计划。,7.1.2 存储过程的创建与执行,2)注意事项存储过程的执行要注意以下几点:(1)如果存储过程名的前缀为“sp_”,SQL Server会首先在master数据库中寻找符合该名称的系统存储过程。如果没能找到合法的过程名,SQL Server才会寻找架构名称为dbo的存储过程。(2)在执行存储过程时,若语句是批处理中的第一个语句,则不一定要指定EXECUTE关键字。,7.1.2 存储过程的创建与执行,3)举例(1)设计简单的存储过程。【例7.1】 返回081101号学生的成绩情况。该存储过程不使用任何参数。USE PXSCJGOCREATE PROCEDURE student_info AS SELECT * FROM CJB WHERE 学号= 081101GO存储过程定义后,执行存储过程student_info:EXECUTE student_info如果该存储过程是批处理中的第一条语句,则可使用:student_info执行结果如图7.1所示。,7.1.2 存储过程的创建与执行,(2)使用带参数的存储过程。【例7.2】 从PXSCJ数据库的三个表中查询某人指定课程的成绩和学分。该存储过程接收与传递参数精确匹配的值。USE PXSCJGOCREATE PROCEDURE student_info1 name char (8), cname char(16) AS SELECT a.学号, 姓名, 课程名, 成绩, t.学分 FROM XSB a INNER JOIN CJB b ON a.学号 = b.学号 INNER JOIN KCB t ON b.课程号= t.课程号 WHERE a.姓名=name and t.课程名=cnameGO,7.1.2 存储过程的创建与执行,执行存储过程student_info1:EXECUTE student_info1 王林, 计算机基础执行结果如图7.2所示。,以下命令的执行结果与上面的相同:EXECUTE student_info1 name=王林, cname=计算机基础或者:DECLARE proc char(20)SET proc= student_info1EXECUTE proc name=王林, cname=计算机基础,7.1.2 存储过程的创建与执行,(3)使用带OUPUT参数的存储过程。【例7.3】 创建一个存储过程do_insert,作用是向XSB表中插入一行数据。创建另外一个存储过程do_action,在其中调用第一个存储过程,并根据条件处理该行数据,处理后输出相应的信息。第一个存储过程:CREATE PROCEDURE dbo.do_insert AS INSERT INTO XSB VALUES(091201, 陶伟, 1, 1990-03-05, 软件工程,50, NULL);,7.1.2 存储过程的创建与执行,第二个存储过程:CREATE PROCEDURE do_action X bit, STR CHAR(8) OUTPUT AS BEGIN EXEC do_insert IF X=0 BEGIN UPDATE XSB SET 姓名=刘英, 性别=0 WHERE 学号=091201 SET STR=修改成功 END ELSE IF X=1 BEGIN DELETE FROM XSB WHERE 学号=091201 SET STR=删除成功 END END,7.1.2 存储过程的创建与执行,接下来执行存储过程do_action来查看结果:DECLARE str char(8)EXEC dbo.do_action 0, str OUTPUTSELECT str;执行结果如图7.3所示。,7.1.2 存储过程的创建与执行,(4)使用带有通配符参数的存储过程。【例7.4】 从三个表的连接中返回指定学生的学号、姓名、所选课程名称及该课程的成绩。该存储过程在参数中使用了模式匹配,如果没有提供参数,则使用预设的默认值。CREATE PROCEDURE st_info name varchar(30) = 李% AS SELECT a.学号,a.姓名,c.课程名,b.成绩 FROM XSB a INNER JOIN CJB b ON a.学号 =b.学号 INNER JOIN KCB c ON c.课程号= b.课程号 WHERE 姓名 LIKE nameGO 执行存储过程:EXECUTE st_info /*参数使用默认值*/或者:EXECUTE st_info 王% /*传递给name 的实参为王%*/,7.1.2 存储过程的创建与执行,(5)使用OUTPUT游标参数的存储过程。OUTPUT游标参数用于返回存储过程的局部游标。【例7.5】 在 PXSCJ数据库的XSB表上声明并打开一个游标。CREATE PROCEDURE st_cursor st_cursor cursor VARYING OUTPUT AS SET st_cursor = CURSOR FORWARD_ONLY STATIC FOR SELECT * FROM XSB OPEN st_cursor,7.1.2 存储过程的创建与执行,在如下的批处理中,声明一个局部游标变量,执行上述存储过程,并将游标赋值给局部游标变量,然后通过该游标变量读取记录。DECLARE MyCursor cursorEXEC st_cursor st_cursor = MyCursor OUTPUT/*执行存储过程*/FETCH NEXT FROM MyCursorWHILE (FETCH_STATUS = 0)BEGIN FETCH NEXT FROM MyCursorENDCLOSE MyCursorDEALLOCATE MyCursor,7.1.2 存储过程的创建与执行,(6)使用WITH ENCRYPTION选项。WITH ENCRYPTION子句用于对用户隐藏存储过程的文本。【例7.6】 创建加密过程,使用 sp_helptext 系统存储过程获取关于加密过程的信息,然后尝试直接从 syscomments 表中获取关于该过程的信息。CREATE PROCEDURE encrypt_this WITH ENCRYPTION AS SELECT * FROM XSB通过系统存储过程sp_helptext可显示规则、默认值、未加密的存储过程、用户定义函数、触发器或视图的文本。执行如下语句:EXEC sp_helptext encrypt_this结果集为提示信息“对象encrypt_this的文本已加密”。,7.1.3 存储过程的修改,使用ALTER PROCEDURE命令可修改已存在的存储过程并保留以前赋予的许可。语法格式:ALTER PROC | PROCEDURE 架构名. 过程名 ; 组号 参数 类型架构名. 数据类型 VARYING = default OUTPUT , . WITH , . FOR REPLICATION AS ; . | EXTERNAL NAME 程序集名.类名.方法名 ; ,7.1.3 存储过程的修改,【例7.7】 对例7.2中创建的存储过程student_info1进行修改,将第一个参数改成学生的学号。USE PXSCJGOALTER PROCEDURE student_info1 number char(6),cname char(16) AS SELECT 学号, 课程名, 成绩 FROM CJB, KCB WHERE CJB.学号=number AND KCB.课程名=cnameGO,7.1.3 存储过程的修改,【例7.8】 创建名为select_students的存储过程,在默认情况下,该存储过程可查询所有学生信息,随后授予权限。当该存储过程需更改为能检索计算机专业的学生信息时,用ALTER PROCEDURE命令重新定义该存储过程。创建select_students存储过程:CREATE PROCEDURE select_students /*创建存储过程*/ AS SELECT * FROM XSB ORDER BY 学号GO修改存储过程select_students:ALTER PROCEDURE select_students WITH ENCRYPTION AS SELECT * FROM XSB WHERE 专业= 计算机 ORDER BY 学号GO,7.1.4 存储过程的删除,当不再使用一个存储过程时,就要把它从数据库中删除。使用DROP PROCEDURE语句可永久地删除存储过程。在此之前,必须确认该存储过程没有任何依赖关系。语法格式:DROP PROC | PROCEDURE 架构名. 过程 , . 说明:过程是指要删除的存储过程或存储过程组的名称。USE PXSCJGOIF EXISTS(SELECT name FROM sysobjects WHERE name=student_info) DROP PROCEDURE student_info,7.1.5 界面方式操作存储过程,1创建存储过程例如,如果要通过图形向导方式定义一个存储过程来查询PXSCJ数据库中每个同学各门功课的成绩,那么其主要步骤如下:启动“SQL Server Management Studio”,在“对象资源管理器”中展开“数据库”“PXSCJ”,选择其中的“可编程性”,右击“存储过程”,在弹出的快捷菜单中选择“新建存储过程”菜单项,打开“存储过程脚本编辑”窗口,如图7.4所示。,7.1.5 界面方式操作存储过程,2执行存储过程在PXSCJ数据库的“存储过程”目录下选择要执行的存储过程,如student_info1,右击鼠标,选择“执行存储过程”菜单项。在弹出的“执行过程”窗口中会列出存储过程的参数形式,如果“输出参数”栏为“否”,则表示该参数为输入参数,用户需要设置输入参数的值,在“值”一栏中输入即可,如图7.5所示。,7.1.5 界面方式操作存储过程,3修改存储过程在“存储过程”目录下选择要修改的存储过程,右击鼠标,在弹出的快捷菜单中选择“修改”菜单项,打开“存储过程脚本编辑”窗口,在该窗口中修改相关的T-SQL语句。修改完成后,执行修改后的脚本,若执行成功,则修改了存储过程。4删除存储过程选择要删除的存储过程,右击鼠标,在弹出的快捷菜单中选择“删除”菜单项,根据提示删除该存储过程。,7 . 2 触 发 器,7.2.1 触发器的类型1DML触发器当数据库中发生数据操纵语言(DML)事件时将调用DML触发器。一般情况下,DML事件包括对表或视图的INSERT语句、UPDATE语句和DELETE语句,因而DML触发器也可分为三种类型:INSERT、UPDATE和DELETE。利用DML触发器可以方便地保持数据库中数据的完整性。例如,对于PXSCJ数据库有XSB表、CJB表和KCB表,当插入某一学号的学生某一课程的成绩时,该学号应是XSB表中已存在的,课程号应是KCB表中已存在的,此时,可通过定义INSERT触发器实现上述功能。通过DML触发器可以实现多个表间数据的一致性。,7.2.1 触发器的类型,2DDL触发器DDL触发器也是由相应的事件触发的,但DDL触发器触发的事件是数据定义语句(DDL)。这些语句主要是以CREATE、ALTER、DROP等关键字开头的语句。DDL触发器的主要作用是执行管理操作,如审核系统、控制数据库的操作等。通常情况下,DDL触发器主要用于以下一些操作需求:防止对数据库架构进行某些修改;希望数据库中发生某些变化以利于相应数据库架构中的更改;记录数据库架构中的更改或事件。DDL触发器只在响应由T-SQL语法所指定的DDL事件时才会触发。,7.2.2 触发器的创建,1创建DML触发器语法格式:CREATE TRIGGER 架构名. 触发器名 ON 表 | 视图 /*指定操作对象*/ WITH ENCRYPTION /*说明是否采用加密方式*/ FOR |AFTER | INSTEAD OF INSERT , UPDATE , DELETE WITH APPEND NOT FOR REPLICATION /*说明该触发器不用于复制*/AS SQL语句 ; . | EXTERNAL NAME 程序集名.类名.方法名,7.2.2 触发器的创建,1)语句说明(1)触发器名:用于指定触发器名,触发器名必须符合标识符规则,并且在数据库中必须唯一。“架构名”是DML触发器所属架构的名称。对于DDL触发器,无法指定架构名。(2)表 | 视图:指在其上执行触发器的表或视图,有时称为触发器表或触发器视图。(3)AFTER:用于说明触发器在指定操作都成功执行后触发,如AFTER INSERT表示向表中插入数据时激活触发器。不能在视图上定义AFTER触发器。(4)INSTEAD OF:指定用DML触发器中的操作代替触发语句的操作。(5) INSERT , UPDATE , DELETE :指定激活触发器的语句的类型,必须至少指定一个选项。在触发器定义中允许使用上述选项的任意顺序组合。(6)WITH APPEND:指定应该再添加一个现有类型的触发器。(7)SQL语句:触发器的T-SQL语句,可以有一条或多条语句,指定DML触发器触发后将要执行的动作。,7.2.2 触发器的创建,2)触发器说明触发器有以下几点说明:(1)触发器中使用的特殊表。执行触发器时,系统创建了两个特殊的临时表inserted表和deleted表,下面介绍一下这两个表的内容。inserted表:当向表中插入数据时,INSERT触发器触发执行,新的记录插入到触发器表和inserted表中。deleted表:用于保存已从表中删除的记录,当触发一个DELETE触发器时,被删除的记录存放到deleted表中。,7.2.2 触发器的创建,(2)创建DML触发器的说明。创建DML触发器时主要有以下几点说明: CREATE TRIGGER 语句必须是批处理中的第一条语句,并且只能应用到一个表中。 DML触发器只能在当前的数据库中创建,但可以引用当前数据库的外部对象。 创建DML触发器的权限默认分配给表的所有者。 在同一CREATE TRIGGER语句中,可以为多种操作(如INSERT和UPDATE)定义相同的触发器操作。 不能对临时表或系统表创建DML触发器。 对于含有DELETE或UPDATE操作定义的外键表,不能使用INSTEAD OF DELETE和INSTEAD OF UPDATE触发器。,7.2.2 触发器的创建, TRUNCATE TABLE语句虽然能够删除表中的记录,但它不会触发DELETE触发器。 在触发器内可以指定任意的SET语句,所选择的SET选项在触发器执行期间有效,并在触发器执行完后恢复到以前的设置。 DML触发器最大的用途是返回行级数据的完整性,而不是返回结果,所以应当尽量避免返回任何结果集。 CREATE TRIGGER权限默认授予定义触发器的表所有者、sysadmin固定服务器角色成员、db_owner和db_ddladmin固定数据库角色成员,并且不可转让。 DML触发器中不能包含以下语句:ALTER DATABASE、CREATE DATABASE、DROP DATABASE、LOAD DATABASE、LOAD LOG、RECONFIGURE、RESTORE DATABASE、RESTORE LOG。,7.2.2 触发器的创建,(3)创建INSERT触发器。INSERT触发器是当对触发器表执行INSERT语句时就会激活的触发器。INSERT触发器可以用来修改,甚至拒绝接收正在插入的记录。【例7.10】 创建一个表table1,其中只有一列a。在表上创建一个触发器,每次插入操作时,将变量str的值设为“TRIGGER IS WORKING”并显示。USE PXSCJGOCREATE TABLE table1(a int)GOCREATE TRIGGER table1_insert ON table1 AFTER INSERT AS BEGIN DECLARE str char(50) SET str=TRIGGER IS WORKING PRINT str END,7.2.2 触发器的创建,向table1中插入一行数据:INSERT INTO table1 VALUES(10)执行结果如图7.6所示。,7.2.2 触发器的创建,【例7.11】 创建触发器,当向CJB表中插入一个学生的成绩时,将XSB表中该学生的总学分加上添加的课程的学分。CREATE TRIGGER cjb_insert ON CJB AFTER INSERT AS BEGIN DECLARE num char(6), kc_num char(3) DECLARE xf int SELECT num=学号, kc_num=课程号 from inserted SELECT xf=学分 FROM KCB WHERE 课程号=kc_num UPDATE XSB SET 总学分=总学分+xf WHERE 学号=num PRINT 修改成功 END,7.2.2 触发器的创建,(4)创建UPDATE触发器。UPDATE触发器在对触发器表执行UPDATE语句后触发。在执行UPDATE触发器时,将触发器表的原记录保存到deleted临时表中,将修改后的记录保存到inserted临时表中。【例7.12】 创建触发器,当修改XSB表中的学号时,同时也要将CJB表中的学号修改成相应的学号(假设XSB表和CJB表之间没有定义外键约束)。CREATE TRIGGER xsb_update ON XSB AFTER UPDATE AS BEGIN DECLARE old_num char(6), new_num char(6) SELECT old_num=学号 FROM deleted SELECT new_num=学号 FROM inserted UPDATE CJB SET 学号=new_num WHERE 学号=old_num END,7.2.2 触发器的创建,接着修改XSB表中的一行数据,并查看触发器执行结果:UPDATE XSB SET 学号=081120 WHERE 学号=081101GOSELECT * FROM CJB WHERE 学号=081120执行结果如图7.7所示。,7.2.2 触发器的创建,(5)创建DELETE触发器。【例7.13】 在删除XSB表中的一条学生记录时将CJB表中该学生的相应记录也删除。CREATE TRIGGER xsb_delete ON XSB AFTER DELETE AS BEGIN DELETE FROM CJB WHERE 学号 IN(SELECT 学号 FROM deleted) END,7.2.2 触发器的创建,【例7.14】 在KCB表中创建UPDATE和DELETE触发器,当修改或删除KCB表中的课程号字段时,同时修改或删除CJB表中的该课程号。CREATE TRIGGER kcb_trig ON KCB AFTER UPDATE, DELETE AS BEGIN IF (UPDATE(课程号) UPDATE CJB SET 课程号=(SELECT 课程号 FROM inserted) WHERE 课程号=(SELECT 课程号 FROM deleted) ELSE DELETE FROM CJB WHERE 课程号 IN(SELECT 课程号 FROM deleted) END,7.2.2 触发器的创建,(6)创建INSTEAD OF触发器。AFTER触发器是在触发语句执行后触发的,与AFTER触发器不同的是,INSTEAD OF触发器触发时只执行触发器内部的SQL语句,而不执行激活该触发器的SQL语句。一个表或视图中只能有一个INSTEAD OF触发器。【例7.15】 创建表table2,值包含一列a,在表中创建INSTEAD OF INSERT触发器,当向表中插入记录时显示相应消息。USE PXSCJGOCREATE TABLE table2(a int)GOCREATE TRIGGER table2_insert ON table2 INSTEAD OF INSERT AS PRINT INSTEAD OF TRIGGER IS WORKING向表中插入一行数据:INSERT INTO table2 VALUES(10)执行结果如图7.8所示。,7.2.2 触发器的创建,【例7.16】 在PXSCJ数据库中创建视图stu_view,包含学生学号、专业、课程号、成绩。该视图依赖于表XSB和CJB,是不可更新视图。可以在视图上创建INSTEAD OF触发器,当向视图中插入数据时分别向表XSB和CJB插入数据,从而实现向视图插入数据的功能。创建视图:CREATE VIEW stu_viewAS SELECT XSB.学号, 专业, 课程号, 成绩 FROM XSB, CJB WHERE XSB.学号=CJB.学号,7.2.2 触发器的创建,创建INSTEAD OF触发器:CREATE TRIGGER InsteadTrig ON stu_view INSTEAD OF INSERT AS BEGIN DECLARE XH char(6), XM char(8), ZY char(12), KCH char(3), CJ int SET XM=佚名 SELECT XH=学号, ZY=专业, KCH=课程号, CJ=成绩 FROM inserted INSERT INTO XSB(学号, 姓名, 专业) VALUES(XH, XM, ZY) INSERT INTO CJB VALUES(XH, KCH, CJ) END,7.2.2 触发器的创建,向视图插入一行数据:INSERT INTO stu_view VALUES(091102, 计算机, 101, 85 )查看数据是否插入:SELECT * FROM stu_view WHERE 学号= 091102执行结果如图7.9所示。,7.2.2 触发器的创建,查看与视图关联的XSB表的情况:SELECT * FROM XSB WHERE 学号= 091102执行结果如图7.10所示。,7.2.2 触发器的创建,2创建DDL触发器语法格式:CREATE TRIGGER 触发器名 ON ALL SERVER | DATABASE WITH ENCRYPTION FOR | AFTER 事件类型 | 事件组 , . AS SQL语句 ; . | EXTERNAL NAME 程序集名.类名.方法名,7.2.2 触发器的创建,【例7.17】 创建PXSCJ数据库作用域的DDL触发器,当删除一个表时,提示禁止该操作,然后回滚删除表的操作。USE PXSCJGOCREATE TRIGGER safety ON DATABASE AFTER DROP_TABLE AS PRINT 不能删除该表 ROLLBACK TRANSACTION尝试删除表table1:DROP TABLE table1执行结果如图7.11所示。,7.2.2 触发器的创建,【例7.18】 创建服务器作用域的DDL触发器,当删除一个数据库时,提示禁止该操作并回滚删除数据库的操作。CREATE TRIGGER safety_server ON ALL SERVER AFTER DROP_DATABASE AS PRINT 不能删除该数据库 ROLLBACK TRANSACTION,7.2.3 触发器的修改,要修改触发器执行的操作,可以使用ALTER TRIGGER语句。(1)修改DML触发器的语法格式:ALTER TRIGGER 架构名.触发器名 ON ( 表 | 视图 ) WITH ENCRYPTION ( FOR | AFTER | INSTEAD OF ) DELETE , INSERT , UPDATE NOT FOR REPLICATION AS SQL语句 ; . | EXTERNAL NAME 程序集名.类名.方法名,7.2.3 触发器的修改,(2)修改DDL触发器的语法格式:ALTER TRIGGER 触发器名 ON DATABASE | ALL SERVER WITH ENCRYPTION FOR | AFTER 事件类型 , . | 事件组 AS SQL语句 ; | EXTERNAL NAME 程序集名.类名.方法名 ; ,7.2.3 触发器的修改,【例7.19】 修改PXSCJ数据库中在XSB表上定义的触发器xsb_delete,将其修改为UPDATE触发器。USE PXSCJGOALTER TRIGGER xsb_delete ON XSB FOR UPDATE AS PRINT 执行的操作是修改,7.2.4 触发器的删除,触发器本身是存在于表中的,因此,当表被删除时,表中的触发器也将一起被删除。删除触发器使用DROP TRIGGER语句。语法格式:DROP TRIGGER 架构名.触发器名 ,. ; /*删除DML触发器*/DROP TRIGGER 触发器名 ,. ON DATABASE | ALL SERVER ; /*删除DDL触发器*/【例7.20】 删除DML触发器xsb_delete。IF EXISTS (SELECT name FROM sysobjects WHERE name = xsb_delete) DROP TRIGGER xsb_delete【例7.21】 删除DDL触发器safety。DROP TRIGGER safety ON DATABASE,7.2.5 界面方式操作触发器,1创建触发器(1)通过界面方式只能创建DML触发器。以在表XSB上创建触发器为例,利用“对象资源管理器”创建DML触发器的步骤如下:启动“SQLServerManagementStudio”,在“对象资源管理器”中展开“数据库”“PXSCJ”“表”“dbo.XSB”,选择其中的“触发器”目录,在该目录下可以看到之前已经创建的XSB表的触发器。右击“触发器”,在弹出的快捷菜单中选择“新建触发器”菜单项。在打开的“触发器脚本编辑”窗口输入相应的创建触发器的命令。输入完成后,单击“执行”按钮,若执行成功,则触发器创建完成。(2)查看DDL触发器。DDL触发器不可以使用界面方式创建,DDL触发器分为数据库触发器和服务器触发器,展开“数据库”“PXSCJ”“可编程性”“数据库触发器”,可以查看到有哪些数据库触发器。展开“数据库”“服务器对象”“触发器”,可以查看到有哪些服务器触发器。,7.2.5 界面方式操作触发器,2修改触发器DML触发器能够使用界面方式修改,DDL触发器则不可以。进入“对象资源管理器”,修改触发器的步骤与创建的步骤相同,在“对象资源管理器”中选择要修改的触发器,右击鼠标,在弹出的快捷菜单中选择“修改”菜单项,打开“触发器脚本编辑”窗口,在该窗口中可以进行触发器的修改,修改后单击“执行”按钮重新执行即可。但是被设置成“WITH ENCRYPTION”的触发器是不能被修改的。,7.2.5 界面方式操作触发器,3删除触发器(1)删除DML触发器。以XSB表的DML触发器为例,在“对象资源管理器”中展开“数据库”“PXSCJ”“表”“dbo.XSB”“触发器”,选择要删除的触发器名称,右击鼠标,在弹出的快捷菜单中选择“删除”菜单项,在弹出的“删除对象”窗口中单击“确定”按钮,即可完成触发器的删除操作。(2)删除DDL触发器。删除DDL触发器与删除DML触发器的方法类似,首先找到要删除的触发器,右击鼠标,选择“删除”选项即可。,

    注意事项

    本文(第7章存储过程和触发器课件.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开