SQL高级知识V2——触发器(上)

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介: SQL数据库开发

触发器的定义

触发器(trigger)是SQL Server提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( INSERT,DELETE, UPDATE)时就会激活它执行。


触发器的作用

触发器的主要作用就是其能够实现由主键和外键所不能保证的复杂参照完整性和数据的一致性,它能够对数据库中的相关表进行级联修改,提高比CHECK约束更复杂的的数据完整性,并自定义错误消息。


触发器的主要作用主要有以下接个方面

  • 强制数据库间的引用完整性
  • 级联修改数据库中所有相关的表,自动触发其它与之相关的操作
  • 跟踪变化,撤销或回滚违法操作,防止非法修改数据
  • 返回自定义的错误消息,约束无法返回信息,而触发器可以
  • 触发器可以调用更多的存储过程


触发器的优点

  • 触发器是自动的。当对表中的数据做了任何修改之后立即被激活。
  • 触发器可以通过数据库中的相关表进行层叠修改。
  • 触发器可以强制限制。这些限制比用CHECK约束所定义的更复杂。与CHECK约束不同的是,触发器可以引用其他表中的列。

触发器的分类

 SQL Server包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。


DML(数据操作语言,Data Manipulation Language)触发器

DML触发器是一些附加在特定表或视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。


SQL Server中的DML触发器有三种:

  • INSERT触发器:向表中插入数据时被触发;
  • DELETE触发器:从表中删除数据时被触发;
  • UPDATE触发器:修改表中数据时被触发。


当遇到下列情形时,应考虑使用DML触发器:

  • 通过数据库中的相关表实现级联更改
  • 防止恶意或者错误的INSERTDELETEUPDATE操作,并强制执行CHECK约束定义的限制更为复杂的其他限制。
  • 评估数据修改前后表的状态,并根据该差异才去措施。


DDL(数据定义语言,Data Definition Language)触发器

DDL触发器是当服务器或者数据库中发生数据定义语言(主要是CREATE,DROP,ALTER开头的语句)事件时被激活使用,使用DDL触发器可以防止对数据架构进行的某些更改或记录数据中的更改或事件操作。


登录触发器

登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。

触发器的工作原理

触发器触发时:

  • 系统自动在内存中创建INSERTED表或DELETED表;
  • 只读,不允许修改,触发器执行完成后,自动删除。

INSERTED表:

  • 临时保存了插入或更新后的记录行;
  • 可以从INSERTED表中检查插入的数据是否满足业务需求;
  • 如果不满足,则向用户发送报告错误消息,并回滚插入操作。 


DELETED表:

  • 临时保存了删除或更新前的记录行;
  • 可以从DELETED表中检查被删除的数据是否满足业务需求;
  • 如果不满足,则向用户报告错误消息,并回滚插入操作。


INSERTED表和DELETED表对照: 

修改操作记录 INSERTED DELETED
增加(INSERT)记录 存放新增的记录 /
删除(DELETE)记录 / 存放被删除的记录
修改(UPDATE)记录 存放更新后的记录 存放更新前的记录


创建触发器

创建触发器的语法:

CREATE TRIGGER trigger_name ON table_name

[WITH ENCRYPTION]

FOR | AFTER | INSTEAD

OF [DELETE, INSERT, UPDATE]

AS

T-SQL语句

GO

注:

WITH ENCRYPTION 表示加密触发器定义的SQL文本
DELETE, INSERT, UPDATE指定触发器的类型


触发器示例

创建学生表

1.png



相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
4月前
|
SQL
SQL 的 AND、OR 和 NOT 运算符:条件筛选的高级用法
SQL的AND运算符用于根据多个条件筛选记录,确保所有条件都为TRUE才返回记录。下面是AND运算符的基本语法:
52 1
|
6月前
|
SQL 监控 关系型数据库
【MYSQL高级】Mysql找出执行慢的SQL【慢查询日志使用与分析】
【MYSQL高级】Mysql找出执行慢的SQL【慢查询日志使用与分析】
456 0
|
6月前
|
SQL 存储 关系型数据库
【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
94 0
|
1月前
|
SQL 存储 数据可视化
10个高级的 SQL 查询技巧
10个高级的 SQL 查询技巧
|
3月前
|
SQL Oracle 关系型数据库
整合Mybatis-Plus高级,Oracle 主键Sequence,Sql 注入器实现自定义全局操作
整合Mybatis-Plus高级,Oracle 主键Sequence,Sql 注入器实现自定义全局操作
89 0
|
6月前
|
SQL 存储 关系型数据库
【MYSQL高级】Mysql的SQL性能分析【借助EXPLAIN分析】
【MYSQL高级】Mysql的SQL性能分析【借助EXPLAIN分析】
73 0
|
3月前
|
SQL 存储 数据库
PL/SQL触发器的概述和用途
PL/SQL触发器的概述和用途
32 2
|
3月前
|
存储 SQL 关系型数据库
SQL联结表及高级联结
SQL联结表及高级联结
28 0
|
3月前
|
SQL OLAP Serverless
第五章:SQL高级处理---SQL学习笔记
第五章:SQL高级处理---SQL学习笔记
40 0
|
4月前
|
SQL 存储
百度搜索:蓝易云【高级SQL语句】
这些是SQL中一些常见的高级语句示例,它们可以帮助你处理更复杂的查询和数据操作需求。请根据具体情况选择适当的语句,并参考相关的SQL文档和教程来进一步了解和学习。
36 0