SQLServer触发器的使用
SQLServer-触发器使用实例

SQLServer 触发器使用实例触发器是一个特殊的存储过程。
常见的有三种:分别使用于Insert , Update , Delete 事件。
一、Trigger语法:create trigger tr_nameon table/view{for | after | instead of } [update][,][insert][,][delete][with encryption]as {batch | if update (col_name) [{and|or} update (col_name)] }说明:1 tr_name :名称2 on table/view :触发器所作用的表。
一个触发器只能作用于一个表3 for 和after :同义4 after 和instead of :sql 2000新增项目afrer 和instead of 的区别After在触发事件发生以后才被激活,只可以建立在表上Instead of代替了相应的触发事件而被执行,既可以建立在表上也可以建立在视图上5 insert、update、delete:激活触发器的三种操作,可以同时执行,也可选其一6 if update (col_name):表明所作的操作对指定列是否有影响,有影响,则激活触发器。
此外,因为delete 操作只对行有影响,所以如果使用delete操作就不能用这条语句了(虽然使用也不出错,但是不能激活触发器,没意义)。
7 触发器执行时用到的两个特殊表:deleted ,inserteddeleted 和inserted 可以说是一种特殊的临时表,是在进行激活触发器时由系统自动生成的,其结构和触发器作用的表结构是一样的,只是存放的数据有差异。
二、实例:实例1(注意这里的关联,条件是如何关联,update中set的值是和谁关联。
这些都可以从【触发器的两个临时表:inserted、deleted】中得到答案)比如,这么两个表:Create Table Student( --学生表StudentID int primary key, --学号StudentName varchar(50),姓名)Create Table BorrowRecord( --学生借书记录表BorrowRecord int identity(1,1), --流水号StudentID int , --学号BorrowDate datetime, --借出时间ReturnDAte Datetime, --归还时间...)用到的功能有:1.如果我更改了学生的学号,我希望他的借书记录仍然和这个学生相关(也就是同时更改借书记录表的学号);2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。
sql server触发器的基本语法和使用方法

sql server触发器的基本语法和使用方法一、引言SQL Server触发器是一种数据库对象,它在数据库表上定义在特定事件发生时自动执行的操作。
触发器基于定义的事件和条件进行触发,并执行一系列预定的操作。
本文将介绍SQL Server触发器的基本语法和使用方法,帮助您更好地理解和应用触发器。
二、触发器的语法触发器的语法主要由以下几个部分组成:1. 触发器名称:指定触发器的名称,以便在创建触发器时进行命名和识别。
2. 触发器事件:指定触发器应何时触发,常见的触发器事件包括INSERT、UPDATE和DELETE等。
3. 触发器模式:指定触发器在事件发生时执行的操作,包括对表数据的插入、更新和删除等操作。
4. 触发器所在的架构:指定触发器所在的架构,以便在创建触发器时指定正确的架构。
基本语法示例:CREATE TRIGGER trigger_name ON table_name FOR INSERT, UPDATE, DELETE AS BEGIN -- 触发器操作代码 END;三、触发器的使用方法1. 创建触发器:使用CREATE TRIGGER语句创建触发器,指定触发器的名称、事件、模式和所在的架构。
2. 禁用和启用触发器:使用ALTER TRIGGER语句来禁用和启用触发器,以满足特定需求或临时更改触发器的行为。
3. 修改触发器:使用ALTER TRIGGER语句修改现有触发器的名称、事件、模式和位置等属性。
4. 删除触发器:使用DROP TRIGGER语句删除不再需要的触发器。
5. 触发器的嵌套:在触发器内部可以定义其他触发器,形成嵌套结构,实现更复杂的逻辑。
6. 触发器的权限:确保创建、修改和删除触发器的用户具有足够的权限。
7. 异常处理:在触发器操作代码中添加适当的异常处理机制,以应对可能出现的错误和异常情况。
四、示例以下是一个简单的示例,展示如何使用SQL Server触发器在表上定义一个插入操作时自动添加日志:1. 创建表:首先创建一个包含要记录的字段的表。
sqlserver 触发器判断条件

在SQL Server 中,触发器(Trigger)是一种特殊的存储过程,它会在特定的数据修改操作(如INSERT、UPDATE 或DELETE)发生时自动执行。
你可以使用触发器来执行各种任务,如验证数据、执行审计、确保数据完整性等。
在触发器中,你可以使用 INSERTED 和 DELETED 这两个特殊的表来访问被修改的数据。
INSERTED 表包含新插入或修改后的数据,而 DELETED 表包含被删除或修改前的数据。
以下是一个简单的例子,展示了如何在触发器中使用条件判断:
假设我们有一个名为 Employees 的表,我们想在每次插入新员工时检查其工资是否低于某个值(例如2000)。
如果是,则触发器会阻止这次插入操作。
在上述触发器中,我们使用了 INSERTED 表来访问新插入的数据,并使用 ROLLBACK TRANSACTION 来撤销这次插入操作。
我们还使用了 RAISERROR 来抛出一个错误消息,告诉用户为什么插入操作被阻止。
sqlserver中数据增删改 触发器写法

SQL Server是一种关系型数据库管理系统,用于在计算机和服务器上存储和检索数据。
在SQL Server中,数据的增删改操作是非常常见的,而触发器则是一种在数据库中定义的特殊的存储过程,它可以在数据被修改时自动执行。
本文将介绍SQL Server中数据增删改触发器的写法并提供实例演示。
一、触发器的基本概念1.1 触发器定义触发器是一种与表相关的数据库对象,它会在表上插入、更新或删除数据时自动执行。
1.2 触发器分类在SQL Server中,触发器分为INSERT触发器、UPDATE触发器和DELETE触发器,分别表示在数据插入、更新和删除操作时触发执行。
二、触发器的创建与使用2.1 创建触发器在SQL Server中,可以使用CREATE TRIGGER语句创建一个触发器,语法如下:```sqlCREATE TRIGGER trigger_nameON table_nameAFTER INSERT, UPDATE, DELETEASBEGIN-- 触发器执行的逻辑END```2.2 触发器的执行时机在创建触发器时,需要指定触发器执行的时机,包括AFTER和INSTEAD OF两种选项。
AFTER表示在数据操作之后执行触发器逻辑,而INSTEAD OF表示在数据操作之前执行触发器逻辑。
2.3 触发器的使用一旦创建了触发器,它会在指定的操作发生时自动执行,无需手动调用触发器。
三、触发器的编写实例下面我们以一个实际的案例,演示如何在SQL Server中编写数据增删改触发器。
3.1 创建测试表我们创建一个测试表TestTable,用于存储测试数据,表结构如下:```sqlCREATE TABLE TestTable(ID INT PRIMARY KEY,Name NVARCHAR(50))```3.2 创建INSERT触发器接下来,我们创建一个INSERT触发器,当往TestTable表中插入数据时,自动将数据插入到另一个备份表BackupTable中。
sql server触发器的使用及语法

SQL Server触发器是一种特殊的数据库对象,它可以在表上定义,用于在特定的数据操作(如插入、更新、删除)发生时自动执行一段代码。
触发器可以用于实现数据约束、数据审计、数据变更记录等功能。
以下是SQL Server触发器的使用及语法:.创建触发器:CREATE TRIGGER trigger_name{AFTER | INSTEAD OF} {INSERT | UPDATE | DELETE} ON table_name[WITH ENCRYPTION][FOR | AFTER] {INSERT | UPDATE | DELETE}ASBEGIN-- 触发器执行的代码END.删除触发器:DROP TRIGGER [schema_name.]trigger_name.触发器的类型:•AFTER触发器:在数据操作之后触发执行。
•INSTEAD OF触发器:在数据操作之前触发执行,可以替代原始操作。
.触发器的事件:•INSERT:在向表中插入数据时触发。
•UPDATE:在更新表中的数据时触发。
•DELETE:在从表中删除数据时触发。
.触发器的执行时间:•FOR:在数据操作之前或之后触发执行。
•AFTER:在数据操作之后触发执行。
触发器的代码:触发器的代码可以包含SQL语句、存储过程、函数等。
可以使用INSERTED和DELETED临时表来访问触发器操作的数据。
INSERTED表包含已插入或已更新的数据,DELETED表包含已删除或已更新的数据。
触发器的加密:使用WITH ENCRYPTION选项可以对触发器的定义进行加密,防止他人查看触发器的代码。
需要注意的是,触发器的使用应该谨慎,过多或复杂的触发器可能会影响数据库的性能。
在设计和使用触发器时,要考虑到对数据库性能的影响,并经过充分测试和优化。
sqlserver触发器例题

sqlserver触发器例题SQL Server 触发器是一种数据库对象,它可以在特定表上的数据发生更改时自动执行一系列操作。
触发器可以用于实现业务规则和数据完整性约束,以及跟踪数据变化等功能。
在本文中,我们将介绍两个 SQL Server 触发器的例题及其解决方案。
例题一:在一张名为"Employee"的表上创建一个触发器,以便在插入新员工记录时自动将当前日期作为"hire_date"字段的默认值。
解决方案:首先,我们需要使用下面的 SQL 命令创建一个名为"Employee"的表,并在该表中添加一个"hire_date"字段:```sql CREATE TABLE Employee ( employee_id INT PRIMARY KEY, employee_name VARCHAR(50), hire_date DATE ) ```接下来,我们可以使用下面的 SQL 命令创建一个名为"trg_Employee_Insert"的触发器:```sql CREATE TRIGGER trg_Employee_Insert ON Employee FOR INSERT AS BEGIN UPDATE Employee SET hire_date = GETDATE() WHERE employee_id IN (SELECT employee_id FROM inserted) END ```在这个触发器中,我们使用了"FOR INSERT"来指定触发器在插入操作之后执行。
然后,我们使用了"GETDATE()"函数来获取当前日期,并将其更新到"hire_date"字段中。
现在,当我们向"Employee"表中插入一条新的员工记录时,触发器将自动将当前日期作为"hire_date"字段的默认值:```sql INSERT INTO Employee (employee_id, employee_name) VALUES (1, 'John') ```例题二:在一张名为"Orders"的表上创建一个触发器,以便在删除订单记录时自动将相应的产品库存加回去。
sqlserver 触发器if else语句

sqlserver 触发器if else语句SQL Server 触发器是一个使 SQL Server 数据库自动执行某些操作的特殊程序。
在执行特定的 SQL Server 数据库操作时,SQL Server 总是先运行触发器,然后再执行所请求的操作。
触发器可以执行各种操作,例如插入、更新或删除数据。
在编写一个 SQL Server 触发器时,可以使用 if else 语句来控制不同的操作。
If else 语句是 SQL Server 中常用的控制语句,可以根据指定的条件执行不同的操作。
在 SQL Server 触发器中,if else 语句可以用来控制触发器在满足特定条件时执行特定的 SQL 代码。
一个简单的 if else 语句可以如下所示:IF conditionBEGIN--执行操作AENDELSEBEGIN--执行操作BEND在 SQL Server 触发器中,if else 语句可以用于控制触发器执行特定的操作。
例如,可以在触发器中使用 if else 语句来检查特定的条件,然后基于该条件对目标表进行插入、更新或删除操作。
以下是一个在 SQL Server 触发器中使用 if else 语句的示例: CREATE TRIGGER trigger_nameON table_nameAFTER INSERT --触发器会在插入操作之后执行,其他操作类似ASBEGINDECLARE @var1 INT; --定义变量SET @var1 = (SELECT COUNT(*) FROM table_name); --将表中的行数赋给变量IF (@var1 > 10) --检查条件BEGIN--执行操作AUPDATE table_name SET column1='new_value' WHEREcolumn2='value2';ENDELSEBEGIN--执行操作BDELETE FROM table_name WHERE column3='value3';ENDEND;以上触发器将在插入操作之后执行,如果表中行数大于10,则更新列1,否则删除特定列的值。
SQLSERVER触发器触发INSERT,UPDATE,DELETE三种状态

SQLSERVER触发器触发INSERT,UPDATE,DELETE三种状态SQLSERVER触发器触发INSERT,UPDATE,DELETE三种状态来源:⼀个触发器内三种INSERT,UPDATE,DELETE状态CREATE TRIGGER tr_T_A ON T_A for INSERT,UPDATE,DELETE如IF exists (select * from inserted) and not exists (select * from deleted) 则为 INSERT如IF exists(select * from inserted ) and exists (select * from deleted) 则为 UPDATE如IF exists (select * from deleted) and not exists (select * from inserted)则为 DELETE插⼊操作(Insert):Inserted表有数据,Deleted表⽆数据删除操作(Delete):Inserted表⽆数据,Deleted表有数据更新操作(Update):Inserted表有数据(新数据),Deleted表有数据(旧数据)---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------SQL中触发器的使⽤原⽂地址:https:///feiquan/archive/2018/04/01/8685722.html创建触发器是特殊的存储过程,⾃动执⾏,⼀般不要有返回值类型: 1.后触发器(AFTER,FOR)先执⾏对应语句,后执⾏触发器中的语句 2.前触发器并没有真正的执⾏触发语句(insert,update,delete),⽽是执⾏触发后的语句 3.⾏级触发器(FOR EACH ROW)在SQL server 中不存在商品号为1的库存量:1.后触发器(实现不同表之间的约束)--实现在销售量不⼤于库存量时,每卖出n件商品,对应商品的库存要减n,若销售量⼤于库存量,则回滚此次操作IF EXISTS (SELECT *FROM sysobjects WHERE name='tr_SaleCommodity')DROP TRIGGER tr_SaleCommodityGOCREATE TRIGGER tr_SaleCommodityON OrderInfo FOR INSERT --FOR/AFTER为后触发器ASBEGINIF EXISTS (SELECT * FROM inserted I INNER JOIN CommodityInfo C ON modityId=modityIdWHERE I.Amount>C.Amount)BEGINROLLBACK --后触发器PRINT '商品的销售量⼤于商品的库存量'ENDELSEBEGINUPDATE CommodityInfoSET Amount=Amount-(SELECT Amount FROM inserted)WHERE CommodityId IN(SELECT CommodityId FROM inserted)ENDENDGO执⾏:INSERT INTO OrderInfo(UserId,CommodityId,Amount,PayMoney,PayWay,OrderTime,Confirm,SendGoods)VALUES('YOUYOU',1,10,600,'⽹上银⾏','2014-11-11 00:00:00.000',1,1)结果: 注意:1.上⼀⾏为销售记录,下⼀⾏为商品1的信息 2.卖出10个,库存量由48变为38 3.可以看出以上的销售记录中的Paymoney是不正确的,它的值应该是Amount*OutPrice=10*300,所以需要前触发器来约束2.前触发器(可以实现⾏级触发器功能)--实现了⽇期校验和⽀付⾦额的计算IF EXISTS(SELECT* FROM sysobjects WHERE name='tr_DateConfim')DROP TRIGGER tr_DateConfimGOCREATE TRIGGER tr_DateConfimON OrderInfo INSTEAD OF INSERT ,UPDATEASBEGINDECLARE @date datetimeSELECT @date=OrderTime FROM insertedIF @date BETWEEN '2012-1-1' AND '2015-1-1'BEGINDECLARE @UserId varchar(20) ,@CommodityId int,@Amount int,@PayMoney money,@PayWay varchar(20),@OrderTime datetime,@Confirm int,@SendGoods intSELECT @UserId=UserId,@CommodityId=CommodityId,@Amount=Amount,@PayWay=PayWay,@OrderTime=OrderTime,@Confirm=Confirm,@SendGoods=SendGoods FROM insertedDECLARE @outPrice moneySELECT @outPrice=OutPrice FROM CommodityInfo WHERE CommodityId=@CommodityIdSET @PayMoney=@outPrice*@AmountPRINT 'inserted 中的数据:'+CONVERT(varchar(20),@UserId)+' '+CONVERT(varchar(20),@CommodityId)+' '+CONVERT(varchar(20),@Amount)+' '+CONVERT(varchar(20),@PayMoney)+' '+CONVERT(varchar(20),@PayWay)+' '+CON INSERT INTO OrderInfo(UserId,CommodityId,Amount,PayMoney,PayWay,OrderTime,Confirm,SendGoods)SELECT UserId,CommodityId,Amount,@PayMoney,PayWay,OrderTime,Confirm,SendGoods FROM insertedENDELSEPRINT '你插⼊的数据中的时间只能在 2012-1-1 到 2015-1-1 中间'ENDGO执⾏:INSERT INTO OrderInfo(UserId,CommodityId,Amount,PayWay,OrderTime,Confirm,SendGoods)VALUES('YOUYOU',1,5,'⽹上银⾏','2013-1-11',1,1) 注意:这⾥插⼊时我并没有定义PayMoney,PayMoney是通过触发器来⾃动计算的结果:⽇期不正确:⽇期正确:打印信息对应:@UserId+' '+@CommodityId+' '+@Amount+' '+@PayMoney+' '+@PayWay+' '@OrderTime+' '@Confirm+' '+@SendGoods+' '@outPrice3.⾏级触发器(错误)执⾏结果:可以看出在SQL server中并不⽀持⾏级触发器。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
触发器建立的代码
Create Trigger TG_ProjectName
On table1
After Update
As
Update table2
Set[工程名]=b.工程名
from table2 a,inserted b
where a.ProjID=b.ID
关于触发器中Inserted和Deleted的解释。
inserted触发器语句中使用了两种特殊的表:deleted 表和inserted 表。
Microsoft® SQL Server 2000 自动创建和管理这些表。
可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。
inserted 和deleted 表主要用于触发器中:
◆扩展表间引用完整性。
◆在以视图为基础的基表中插入或更新数据。
◆检查错误并基于错误采取行动。
◆找到数据修改前后表状态的差异,并基于此差异采取行动。
Deleted 表用于存储DELETE 和UPDATE 语句所影响的行的复本。
在执行DELETE 或UPDATE 语句时,行从触发器表中删除,并传输到deleted 表中。
Deleted 表和触发器表通常没有相同的行。
Inserted 表用于存储INSERT 和UPDATE 语句所影响的行的副本。
在一个插入或更新事务处理中,新建行被同时添加到inserted 表和触发器表中。
Inserted 表中的行是触发器表中新行的副本。
更新事务类似于在删除之后执行插入;首先旧行被复制到deleted 表中,然后新行被复制到触发器表和inserted 表中。
在设置触发器条件时,应当为引发触发器的操作恰当使用inserted 和deleted 表。
虽然在测试INSERT 时引用deleted 表或在测试DELETE 时引用inserted 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。
说明
如果触发器操作取决于一个数据修改所影响的行数,应该为多行数据修改(基于SELECT 语句的INSERT、DELETE 或UPDATE)使用测试(如检查@@ROWCOUNT),然后采取相应的对策。
SQL Server 2000不允许AFTER 触发器引用inserted 和deleted 表中的text、ntext 或image 列;然而,允许INSTEAD OF 触发器引用这些列。
有关更多信息,请参见CREATE TRIGGER。
在INSTEAD OF 触发器中使用inserted 和deleted 表
传递到在表上定义的INSTEAD OF 触发器的inserted 和deleted 表遵从与传递到AFTER 触发器的inserted 和deleted 表相同的规则。
inserted 和deleted 表的格式与在其上定义INSTEAD OF 触发器的表的格式相同。
inserted 和deleted 表中的每一列都直接映射到基表中的列。
有关引用带INSTEAD OF 触发器的表的INSERT 或UPDATE 语句何时必须提供列值的规则与表没有INSTEAD OF 触发器时相同:
不能为计算列或具有timestamp 数据类型的列指定值。
不能为具有IDENTITY 属性的列指定值,除非该列的IDENTITY_INSERT 为ON。
当IDENTITY_INSERT 为ON 时,INSERT 语句必须提供一个值。
INSERT 语句必须为所有无DEFAULT 约束的NOT NULL 列提供值。
对于除计算列、标识列或timestamp 列以外的任何列,任何允许空值的列或具有DEFAULT 定义的NOT NULL 列的值都是可选的。
当INSERT、UPDATE 或DELETE 语句引用具有INSTEAD OF 触发器的视图时,数据库引擎将调用该触发器,而不是对任何表采取任何直接操作。
即使为视图生成的inserted 和deleted 表中的信息格式与基表中的数据格式不同,该触发器在生成执行基表中的请求操作所需的任何语句时,仍必须使用inserted 和deleted 表中的信息。
传递到在视图上定义的INSTEAD OF 触发器的inserted 和deleted 表格式与为该视图定义的SELECT 语句的选择列表相匹配。
例如:
CREATEVIEWEmployeeNames(EmployeeID,LName,FName)
AS
SELECTEmployeeID,LastName,FirstName
FROMNorthwind.dbo.Employees
视图的结果集有三列:一个int 列和两个nvarchar 列。
传递到在视图上定义的INSTEAD OF 触发器的inserted 和deleted 表也具有名为EmployeeID 的int 列、名为LName 的nvarchar 列和名为FName 的nvarchar 列。
视图的选择列表还包含不直接映射到单个基表列的表达式。
一些视图表达式(如常量调用或函数调用)可能不引用任何列,这类表达式会被忽略。
复杂的表达式会引用多列,但在inserted 和deleted 表中,每个插入的行仅有一个值。
如果视图中的简单表达式引用具有复杂表达式的计算列,则这些简单表达式也有同样的问题。
视图上的INSTEAD OF 触发器必须处理这些类型的表达式。
有关更多信息,请参见视图上INSTEAD OF 触发器中的表达式和计算列。
顺便说一下,当对某张表建立触发器后,分3种情况讨论
1.插入操作(Insert)
Inserted表有数据,Deleted表无数据
2.删除操作(Delete)
Inserted表无数据,Deleted表有数据
3.更新操作(Update)
Inserted表有数据(新数据),Deleted表有数据(旧数据)。