当前位置:Gxlcms > mssql > SqlServer实现类似Oracle的before触发器示例

SqlServer实现类似Oracle的before触发器示例

时间:2021-07-01 10:21:17 帮助过:31人阅读

1. 插入数据前判断数据是否存在

  1. SET ANSI_NULLS ON
  2. GO
  3. SET QUOTED_IDENTIFIER ON
  4. GO
  5. -- =============================================
  6. -- Author: <Author,,Name>
  7. -- Create date: <Create Date,,>
  8. -- Description: <Description,,>
  9. -- =============================================
  10. alter TRIGGER CategoryExistTrigger
  11. ON ProductCategory
  12. instead of insert
  13. AS
  14. declare @categoryName varchar(50);
  15. BEGIN
  16. -- SET NOCOUNT ON added to prevent extra result sets from
  17. -- interfering with SELECT statements.
  18. SET NOCOUNT ON;
  19. -- Insert statements for trigger here
  20. select @categoryName = CategoryName from inserted;
  21. if exists(select * from ProductCategory where CategoryName =@categoryName)
  22. begin
  23. print 'Category exists..'
  24. end;
  25. else
  26. begin
  27. insert into ProductCategory select * from inserted;
  28. end;
  29. END

2. 删除表中数据时需要先删除外键表的数据

  1. SET ANSI_NULLS ON
  2. GO
  3. SET QUOTED_IDENTIFIER ON
  4. GO
  5. -- =============================================
  6. -- Author: <Author,,Name>
  7. -- Create date: <Create Date,,>
  8. -- Description: <Description,,>
  9. -- =============================================
  10. alter TRIGGER DeleteOrderTrigger
  11. ON OrderHeader
  12. instead of delete
  13. AS
  14. declare @OrderId varchar(50);
  15. BEGIN
  16. SET NOCOUNT ON;
  17. select @OrderId = OrderId from deleted;
  18. delete from OrderLine where OrderId = @OrderId;
  19. END
  20. GO

您可能感兴趣的文章:

  • oracle 触发器 学习笔记
  • Oracle触发器用法实例详解
  • Oracle创建主键自增表(sql语句实现)及触发器应用
  • oracle监控某表变动触发器例子(监控增,删,改)
  • [Oracle] 如何使用触发器实现IP限制用户登录
  • oracle 存储过程和触发器复制数据
  • Oracle 触发器的使用小结
  • ORACLE PL/SQL 触发器编程篇介绍
  • Oracle触发器trigger详解
  • Oracle中触发器示例详解

人气教程排行