数据库原理与应用(SQL Server)笔记 第九章 存储过程和触发器(下)

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 数据库原理与应用(SQL Server)笔记 第九章 存储过程和触发器

二、触发器


(一)触发器的定义


简单的来说,触发器就是一个特殊类型的存储过程,其特殊性就在于其在修改表数据时自动触发执行所定义的语句。它和存储过程的区别是:存储过程是通过其名称直接调用,而触发器是通过事件进行触发从而自动执行。


(二)触发器的特点和分类


1、触发器的特点

触发器较于存储过程首先是其自动执行,另外它是建立在表或视图上的,而存储过程是建立在数据库上的。此外触发器可以实现比约束还更严谨的限制,从而防止被修改。

触发器:

1667040290663.jpg

存储过程:

1667040323878.jpg


2、触发器的分类


触发器分为DML触发器和DDL触发器,这里的DML和DDL的意义分别是数据操作语言和数据定义语言。


(三)触发器中使用的特殊临时表


这里我们要知道在执行触发器时,系统创建了两个特殊的临时表,分别是INSERTED表和DELETED表,它们在触发器执行时被创建,执行完后消失。


1、INSERTED临时表

当向数据表或视图中插入数据时,INSERT触发器执行,将新元组插入INSERTED临时表及基本数据表中,也就是说INSERTED表是包含了已插入元组的一个副本。

1667040378640.jpg


2、DELETED临时表

(1)当向数据表或视图中执行删除操作时,DELETE触发器执行, 将删除的元组存放到DELETED表中。

1667040389985.jpg

(2)而当向数据表或视图中执行更新操作时,UPDATE触发器执行,执行先删除后插入的命令,即先将数据表或视图中的旧元组移至DELETED表中,然后将修改后的新元组插入到INSERTED表中。

1667040402275.jpg


(四)DML触发器


当数据库有数据操作语言事件时,将调用DML触发器,这里包括修改表或视图数据的INSERT语句、UPDATE语句、DELETE语句,即执行增删改操作。如果检测到错误,DML触发器还可以实现整个事务的自动回滚。DML触发器分为AFTER触发器和INSTEAD OF触发器,它们触发条件差不多只不过执行的方式不同。


1、AFTER触发器

后触发型触发器,当用户对表或视图执行INSERT语句、UPDATE语句、DELETE语句之后,触发器被触发。


2、INSTEAD OF触发器

前触发型触发器,当用户对表或视图执行INSERT语句、UPDATE语句、DELETE语句之后,系统不立即执行这些操作,而是将操作内容交给触发器来检查操作是否正确,若正确才继续执行。


(五)DDL触发器


当有对数据定义事件的修改时执行,例CREATE语句、ALTER语句、DROP语句时才被触发,一般用于执行数据库中的管理任务,防止数据表结构被修改等等。


(六)创建触发器


要注意CREATE TRIGGER必须是批处理中的第一条语句,即在USE <表或视图> 后面要加GO批处理,且触发器只能应用到一个表中。

语句格式如下:

CREATE TRIGGER <触发器的名称> ON <表或视图的名称>
AFTER/INSTEAD OF INSERT (UPDATE/DELETE)
/*指定触发器类型以及触发器的语句类型:插入新行或更改某行或删除某行*/
AS
SQL语句


(七)使用触发器


1、使用AFTER触发器

例7、创建Product表的插入触发器tri_1:其功能是当向该表中插入一条新商品记录后,则提示“向Product表中添加了XXX商品记录”。并验证该触发器。

1667040480279.jpg

sql语句:

USE Sales GO CREATE TRIGGER trigger_1 ON Product AFTER INSERT AS DECLARE @ProductName varchar(30) select @ProductName=ProductName FROM INSERTED PRINT '向Product表中添加了'+@ProductName+'商品记录' GO INSERT Product(ProductID,ProductName,CategoryID,Price,stocks) VALUES('P05001','美汁源2000ml','3','13.5','2699')

1667040501312.jpg

例8、创建Category表的UPDATE触发器trigger_2:其功能是防止用户修改Category表中的分类序号ID。并验证该触发器。

1667040512002.jpg

这里的ROLLBACK TRANSACTION即为事务回滚,由于进行了事务回滚,回滚到更新操作之前的状态,所以没有修改CategoryID为1的日用品的CategoryName列的修改。

sql语句:

USE Sales GO CREATE TRIGGER trigger_2 ON Category AFTER UPDATE AS IF UPDATE(CategoryName) BEGIN PRINT '不能修改分类名称' ROLLBACK TRANSACTION END GO --验证该触发器 USE Sales UPDATE Category SET CategoryName='水果' WHERE CategoryID='1' GO

1667040562818.jpg


2、使用INSTEAD OF触发器


与AFTER触发器不同,INSTEAD OF触发器在触发时只执行触发器内部的T-SQL语句,而不执行激活该触发器的T-SQL语句。


例9、创建Category表的INSTEAD OF触发器trigger_3:其功能是防止用户对该表的任何数据进行删除。并验证该触发器。

1667040632568.jpg

这里由于定义了INSTEAD OF触发器,所以并未删除Category表的记录。

sql语句:

USE Sales GO CREATE TRIGGER trigger_3 ON Category INSTEAD OF DELETE AS PRINT '不能删除该表的数据!' GO --验证该触发器 USE Sales DELETE Category WHERE CategoryID='1' GO

1667040652810.jpg


(八)修改触发器


修改触发器使用ALTER TRIGGER语句进行修改,与创建触发器相同,只不过修改DML、DDL触发器不一样。


(九)删除触发器


删除触发器使用DROP TRIGGER语句进行删除,语句格式如下:

DROP TRIGGER <触发器名称>

1667040726094.jpg

(十)触发器的启用和禁用


若暂时不需要使用某个触发器,我们可以禁用该触发器,使用的T-SQL语句是ENABLE/DISABLE TRIGGER语句。

语句格式如下:

ENABLE/DISABLE TRIGGER ON <表或视图的名称>


结语


以上就是本次数据库原理与应用的全部内容,篇幅较长,感谢您的阅读和支持,若有表述或代码中有不当之处,望指出!您的指出和建议能给作者带来很大的动力!!!


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
17天前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
45 11
|
1月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
30天前
|
SQL 监控 安全
SQL Servers审核提高数据库安全性
SQL Server审核是一种追踪和审查SQL Server上所有活动的机制,旨在检测潜在威胁和漏洞,监控服务器设置的更改。审核日志记录安全问题和数据泄露的详细信息,帮助管理员追踪数据库中的特定活动,确保数据安全和合规性。SQL Server审核分为服务器级和数据库级,涵盖登录、配置变更和数据操作等事件。审核工具如EventLog Analyzer提供实时监控和即时告警,帮助快速响应安全事件。
|
2月前
|
SQL 存储 BI
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
|
2月前
|
存储 安全 关系型数据库
2024 Mysql基础与进阶操作系列之MySQL触发器详解(21)作者——LJS[你个小黑子这都还学不会嘛?你是真爱粉嘛?真是的 ~;以后请别侮辱我家鸽鸽]
MySQL触发器的使用场景之数据完整性约束、如何具体创建person的日志表、触发器与存储过程的对比与选择、触发器的性能和注意事项等具体操作详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
7月前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(2)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
7月前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(1)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
5月前
|
存储 关系型数据库 MySQL
MySQL 中的触发器数量之谜
【8月更文挑战第31天】
53 0
|
5月前
|
SQL 数据采集 关系型数据库
|
6月前
|
存储 SQL 关系型数据库
(十四)全解MySQL之各方位事无巨细的剖析存储过程与触发器!
前面的MySQL系列章节中,一直在反复讲述MySQL一些偏理论、底层的知识,很少有涉及到实用技巧的分享,而在本章中则会阐述MySQL一个特别实用的功能,即MySQL的存储过程和触发器。
121 0