当前位置:首页 > 百科大全

sql触发器的使用及语法(sqlserver触发器怎么设置新字段值数据)

2022-11-12 14:57:55

  概述

  触发器(trigger)是SQL server提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,当对一个表进行操作(insert,delete,update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。

  一、触发器的优点

  1.触发器是自动的。当对表中的数据做了任何修改之后立即被激活。

  2.触发器可以通过数据库中的相关表进行层叠修改。

  3.触发器可以强制限制。这些限制比用CHECK约束所定义的更复杂。与CHECK约束不同的是,触发器可以引用其他表中的列。

  二、触发器的分类

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

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

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

  insert触发器:向表中插入数据时被触发;

  delete触发器:从表中删除数据时被触发;

  update触发器:修改表中数据时被触发。

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

  通过数据库中的相关表实现级联更改

  防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。

  评估数据修改前后表的状态,并根据该差异才去措施。

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

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

  3.登录触发器

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

  三、触发器的工作原理

  [DELETE,INSERT,UPDATE]对应为当执行删除、插入、更新三种动作时被触发

  执行insert时,获取插入后的数据,可用select*from inserted读取

  执行delete时,获取删除前的数据,可用select*from deleted读取

  执行update时,获取更新前的数据,可用select*from deleted读取,获取更新后数据,可用select*from inserted读取

  四、创建触发器

  1、创建触发器的语法:

  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指定触发器的类型

  2、创建insert触发器

  --创建insert触发器

  create trigger trig_insert

  on student

  after insert

  as

  begin

  if object_id(N'student_sum',N'U')is null--判断student_sum表是否存在

  create table student_sum(stuCount int default(0));--创建存储学生人数的student_sum表

  declare stuNumber int;

  select stuNumber=count(*)from student;

  if not exists(select*from student_sum)--判断表中是否有记录

  insert into student_sum values(0);

  update student_sum set stuCount= stuNumber;--把更新后总的学生数插入到student_sum表中

  end

  --测试触发器trig_insert-->功能是向student插入数据的同时级联插入到student_sum表中,更新stuCount

  --因为是后触发器,所以先插入数据后,才触发触发器trig_insert;

  insert into student(stu_name,stu_gender,stu_age)values('吕布','男',30);

  select stuCount学生总人数from student_sum;

  insert into student(stu_name,stu_gender,stu_age)values('貂蝉','女',30);

  select stuCount学生总人数from student_sum;

  insert into student(stu_name,stu_gender,stu_age)values('曹阿瞒','男',40);

  select stuCount学生总人数from student_sum;

  3、创建delete触发器

  用户执行delete操作,就会激活delete触发器,从而控制用户能够从数据库中删除数据记录,触发delete触发器后,用户删除的记录会被添加到deleted表中,原来表的相应记录被删除,所以在deleted表中查看删除的记录。

  --创建delete触发器

  create trigger trig_delete

  on student

  after delete

  as

  begin

  select stu_id as已删除的学生编号,stu_name stu_gender,stu_age

  from deleted

  end;

  --执行一一条delete语句触发trig_delete触发器

  delete from student where stu_id=1;

  4、创建UPDATE触发器

  update触发器是当用户在指定表上执行update语句时被调用被调用,这种类型的触发器用来约束用户对数据的修改。update触发器可以执行两种操作:更新前的记录存储在deleted表中,更新后的记录存储在inserted表中。

  --创建update触发器

  create trigger trig_update

  on student

  after update

  as

  begin

  declare stuCount int;

  select stuCount=count(*)from student;

  update student_sum set stuCount= stuCount;

  select stu_id as更新前学生编号,stu_name as更新前学生姓名from deleted

  select stu_id as更新后学生编号,stu_name as更新后学生姓名from inserted

  end

  --创建完成,执行一条update语句触发trig_update触发器

  update student set stu_name='张飞'where stu_id=2;

  五、管理触发器

  1.查看触发器

  (1).查看数据库中所有的触发器

  --查看数据库中所有的触发器

  use数据库名

  go

  select*from sysobjects where xtype='TR'

  sysobjects保存着数据库的对象,其中xtype为TR的记录即为触发器对象。在name一列,我们可以看到触发器名称。

  (2).sp_helptext查看触发器内容

  use数据库名

  go

  exec sp_helptext'触发器名称'

  将会以表的样式显示触发器内容。

  除了触发器外,sp_helptext还可以显示规则、默认值、未加密的存储过程、用户定义函数、视图的文本。

  (3).sp_helptrigger用于查看触发器的属性

  sp_helptrigger有两个参数:第一个参数为表名;第二个为触发器类型,为char(6)类型,可以是INSERT、UPDATE、DELETE,如果省略则显示指定表中所有类型触发器的属性。

  use数据库名

  go

  exec sp_helptrigger tableName

  2.禁用启用触发器

  禁用:alter table表名disable trigger触发器名称

  启用:alter table表名enable trigger触发器名称

  如果有多个触发器,则各个触发器名称之间用英文逗号隔开。

  如果把“触发器名称”换成“ALL”,则表示禁用或启用该表的全部触发器。

  3.修改触发器

  --修改触发器语法

  ALTER TRIGGER trigger_name

  ON table_name

  [WITH ENCRYPTION]

  FOR{[DELETE][,][INSERT][,][UPDATE]}

  AS

  sql_statement;

  4.删除触发器

  --语法格式:

  DROP TRIGGER{trigger}[,...n]

  参数:

  trigger:要删除的触发器名称

  n:表示可以删除多个触发器的占位符

免责声明:本文由用户上传,如有侵权请联系删除!