数据库操作--触发器

触发器是一种特殊类型的存储过程,它不同于存储过程,触发器主要是通过事件进行触发被自动调用执行的,而存储过程可以通过存储过程的名称而被调用。

触发器分为

1、  after触发器

2、  insert触发器

3、  update触发器

4、  delete触发器

触发器是在对表进行插入、更新、删除的时候会自动执行的存储过程。触发器的功能虽然强大,轻松可靠地实现许多复杂的功能,但是过多触发器会造成数据库及应用程序的维护困难,同时对触发器过分的依赖,会影响数据库的结构,同时增加了维护的复杂程序。

在牛腩新闻发布系统中学习了下触发器的使用,在对表中数据进行删除的时候,先删除其他表中的数据,然后执行删除本表中的数据。

 

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">USE [newssystem]  
  2. GO  
  3. /****** Object:  Trigger [dbo].[trigCategoryDelete]    Script Date: 2015/2/8 22:48:11 ******/  
  4. SET ANSI_NULLS ON  
  5. GO  
  6. SET QUOTED_IDENTIFIER ON  
  7. GO  
  8. -- =============================================  
  9. -- Author:      马世超  
  10. -- Create date: 2015-2-4  
  11. -- Description: 删除类别触发器  
  12. -- =============================================  
  13. ALTER TRIGGER [dbo].[trigCategoryDelete]  
  14.    ON  [dbo].[category]  
  15.    instead of delete  
  16. AS   
  17. BEGIN  
  18.     declare @caId int  
  19.     select @caId=id from deleted  
  20.     --删除评论  
  21.     delete comment where newsId in (select newsId from news where caId=@caId)   
  22.     --删除新闻  
  23.     delete news where caid=@caId  
  24.     --删除类别  
  25.     delete category where id=@caId  
  26. END  
  27. </span>  
这次触发器的使用,发现触发器跟视图和存储过程一样,都没有想象中的那么难。触发器应该还有更大的作用,现在只是相当于简单的了解了一下,相信以后用它会发生更大的作用。
1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值