SQL Server触发器

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 简单介绍:    触发器其实是一种特殊的存储过程,它只有在特定的事件发生时自动执行。存储过程和触发器都是SQL语句和流程控制语句的集合,存储过程通过存储过程的名字被直接调用,而触发器主要通过时间进行触发而被执行。

简单介绍:  

  触发器其实是一种特殊的存储过程,它只有在特定的事件发生时自动执行。存储过程和触发器都是SQL语句和流程控制语句的集合,存储过程通过存储过程的名字被直接调用,而触发器主要通过时间进行触发而被执行。

触发器的分类:

  触发器包括DML触发器和DDL触发器。DML触发器是我们常见的一种触发器,当数据库服务器中发生数据操作语言(DML)事件时会自动执行;DDL触发器是一种新型的触发器,它在响应数据定义语言(DDL)语句时触发,一般用于数据库中执行管理任务。今天我们主要研究DML触发器,它又分为AFTER触发器和INSTEAD OF触发器两类。

  AFTER触发器是记录已经改变完成之后才被激活的执行,也就是事件已经结束触发器才被触发;INSTEAD OF触发器是用来取代原本的操作,在事件发生之前触发,这样它并不执行原先的SQL语句,而是按照触发器中的定义操作。

触发条件:

  DML触发器响应UPDATE、INSERT、DELETE语句而激活;DDL触发器响应CREATE、ALTER、DROP、GRANT、DENY、REVOKE、UPDATE以及STATISTICS等语句而激活。

思维导图:

 

创建触发器:

 

 

简单应用:

  以牛腩新闻发布系统中删除新闻类别同时删除新闻以及评论为例,这里因为有外键约束,所以删除新闻类别的同时要删除该类别的新闻以及评论。由于 AFTER触发器是记录已经改变完成之后才被激活的执行,因此我们用INSTEAD OF触发器,把之前单纯的删除类别操作替换为删除评论、新闻以及类别的操作。这样就不会出现外键约束而导致无法删除的情况了。

 

<span style="font-family:KaiTi_GB2312;font-size:18px;">-- =============================================
-- Author:		<邵鸿鑫>
-- Create date: <2014-8-18>
-- Description:	<删除类别触发器>
-- =============================================
ALTER TRIGGER [dbo].[trigCategoryDelete]
   ON [dbo].[category]
   instead of DELETE
AS 
BEGIN
	declare @caId int
	select @caId =id from deleted
	--删除评论
	delete comment where newsId in(select newsId  from news where caId =@caId )
	--删除新闻
	delete news where caId=@caId 
	--删除类别
	delete category where id=@caId 
END
</span>


触发器的作用:

  1)强制比CHECK约束更复杂的数据的完整性

  2)使用自定义的错误提示信息
  3)实现数据库中多张表的级联修改
  4)比较数据库修改前后数据的状态
  5)调用更多的存储过程
  6)维护非规范化数据
触发器的优点还有很多,需要我们到实际应用中去探索,以上有不足之处,希望大家批评指正。

相关实践学习
使用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
目录
相关文章
|
3月前
|
SQL IDE Java
Java连接SQL Server数据库的详细操作流程
Java连接SQL Server数据库的详细操作流程
|
21天前
|
SQL 存储 数据管理
深入理解SQL中的触发器
【8月更文挑战第31天】
13 0
|
2月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
63 13
|
2月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
2月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
44 6
|
1月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
178 0
|
2月前
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
107 1
|
2月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
139 3
|
2月前
|
SQL 存储 安全
数据库数据恢复—SQL Server数据库出现逻辑错误的数据恢复案例
SQL Server数据库数据恢复环境: 某品牌服务器存储中有两组raid5磁盘阵列。操作系统层面跑着SQL Server数据库,SQL Server数据库存放在D盘分区中。 SQL Server数据库故障: 存放SQL Server数据库的D盘分区容量不足,管理员在E盘中生成了一个.ndf的文件并且将数据库路径指向E盘继续使用。数据库继续运行一段时间后出现故障并报错,连接失效,SqlServer数据库无法附加查询。管理员多次尝试恢复数据库数据但是没有成功。
|
2月前
|
SQL 存储 关系型数据库
关系型数据库SQL Server学习
【7月更文挑战第4天】
49 2

热门文章

最新文章