热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

sql触发器怎么使用

sql中的触发器是对某个表进行操作时而触发的某种条件,可以用CREATE语句创建触发器,DROP语句删除触发器,ALTER语句禁用触发器等
sql中的触发器是对某个表进行操作时而触发的某种条件,可以用CREATE语句创建触发器,DROP语句删除触发器,ALTER语句禁用触发器等

触发器

在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。

CREATE TRIGGER tr_update_Stock   --自动采购触发器
ON T_Product
FOR update
AS
IF (update(Stock)) --判断stock字段是否更新
BEGIN
  --查询出库存低于下限的产品近一个月的消耗量
 --创建临时表
 IF object_id('[tempdb].[dbo].##table1') IS NOT NULL --判断临时表#tmp是否存在,存在则删除
    DROP TABLE ##table1
            SELECT * INTO ##table1 FROM (SELECT row_number() OVER (ORDER BY ProductID) AS rowNo,c.ZNumber - c.Stock AS purchaseNum,* FROM (
 SELECT  ProductID,SUM(s.Numbers) ZNumber,p.Stock,SUM(s.OutMoney) ZMoney,p.Price 
 FROM [dbo].[T_StorageOut] t inner join[dbo].[T_StorageRelation] s 
 ON t.StorageOutID=s.StorageOutID inner join T_Product p ON s.ProductID=p.Id
 WHERE t.MakerTime between Convert(VARCHAR,DATEADD(MONTH,-1,GETDATE()),23) and Convert(VARCHAR,GETDATE(),23) and ProductID in (SELECT Id FROM V_ProductSupplierInfo where (Stock-StockLowerLimit)<0)
 GROUP BY ProductID,p.Stock,p.Price) c) ddd
--计算用参数
DECLARE @purchaseNum INT,@Price NVARCHAR(50),@totalMoney NVARCHAR(50),@ZpurchaseTotal INT --采购数量,单价,总金额,总数量
SELECT @totalMOney= 0,@purchaseNum = 0,@Price = 0,@ZpurchaseTotal=0
 --采购单所需参数
  DECLARE @PurchaseNumber NVARCHAR(50),@DopurchaseId INT,@DopurchaseTime NVARCHAR(200),@PurchaseTotal INT,@PurchasePrice NVARCHAR(200),@PurchaseState INT,@PurchaseType INT
   SET @PurchaseNumber=&#39;JH&#39;+replace(replace(replace(convert(VARCHAR,getdate(),120),&#39;-&#39;,&#39;&#39;),&#39; &#39;,&#39;&#39;),&#39;:&#39;,&#39;&#39;) --进货单号JH20171031092322
--采购单详情所需参数 (产品id,产品采购价格)
  DECLARE @StockProductId INT,@DPurchasePrice NVARCHAR(20)
--循环用参数
DECLARE @curIndex INT,@rowCount INT
--判断用参数
DECLARE @OTCount INT,@PTCount INT    
SET @curIndex = 1
SELECT @rowCount = COUNT(1) FROM ##table1
IF(@rowCount>0)
BEGIN
   WHILE @curIndex <= @rowCount
   BEGIN
      --查询出第一行数据的采购数量,单价,产品id
      SELECT @purchaseNum = purchaseNum,@Price = Price,@StockProductId =ProductID FROM ##table1 WHERE rowNo = @curIndex
       --采购总金额
      SET @totalMOney= @totalMoney + @purchaseNum * CONVERT (INT,@price)
      --采购总数量
      SET @ZpurchaseTotal =@ZpurchaseTotal + @purchaseNum  
      --单个产品的采购金额 
      SET @DPurchasePrice=@purchaseNum * CONVERT (INT,@price)
      IF object_id(&#39;[tempdb].[dbo].#PTable&#39;) IS NOT NULL --判断临时表#tmp是否存在,存在则删除
       DROP TABLE #PTable
      IF object_id(&#39;[tempdb].[dbo].#OTable&#39;) IS NOT NULL --判断临时表#tmp是否存在,存在则删除
       DROP TABLE #OTable       
      --根据产品id查询出包含该产品的采购单已全部审批
      SELECT * INTO #PTable FROM (SELECT PurchaseState FROM [dbo].[T_Purchase_Order] WHERE PurchaseNumber in(SELECT PurchaseOrderId FROM  [dbo].[T_Purchase_OrderDetails] WHERE StockProductId=@StockProductId) and PurchaseState=0) AS a
      --根据产品id查询出包含该产品的订单已全部入库
      SELECT * INTO #OTable FROM (SELECT OrderState FROM T_Order WHERE OrderNumber in(SELECT OrderNumber FROM  T_OrderDetails WHERE ProductId=@StockProductId) and OrderState=0) AS c
      SELECT  @PTCount = COUNT(1) FROM #PTable
      SELECT  @OTCount = COUNT(1) FROM #OTable
          IF (@PTCount=0) --已全部审批
          BEGIN
             IF(@OTCount=0) --=0表示包含该产品的订单均已入库,可以生成新的
              BEGIN
               INSERT INTO [dbo].[T_Purchase_OrderDetails] VALUES(@PurchaseNumber,@StockProductId,@purchaseNum,@DPurchasePrice)
              END
          END
      SET @curIndex = @curIndex + 1
   END
END
  set @DopurchaseId = 16646 --自动生成
  set @DopurchaseTime=Convert(NVARCHAR,getdate(),23)   --当前时间 2017-10-31
  set @PurchaseTotal =@ZpurchaseTotal
  set @PurchasePrice =@totalMoney
  set @PurchaseState =0 --未审核
  set @PurchaseType = 2 --自动生成 
  --变量赋值完成,对采购单做添加操作
   IF (@PTCount=0)
   BEGIN
    INSERT INTO T_Purchase_Order VALUES(@PurchaseNumber,@DopurchaseId,@DopurchaseTime,@PurchaseTotal,@PurchasePrice,@PurchaseState,@PurchaseType)
   END
END

这是一个自动采购的触发器,主要需要注意的触发条件,以及临时表的作用。

触发器的使用

创建触发器

CREATE TRIGGER tr_update_Stock

删除触发器

DROP  TRIGGER tr_update_Stock

禁用

ALTER TABLE trig_example DISABLE TRIGGER trig1
GO

恢复

ALTER TABLE trig_example ENABLE TRIGGER trig1
GO

禁用某个表上的所有触发器

ALTER TABLE 你的表 DISABLE TRIGGER all

启用某个表上的所有触发器

ALTER TABLE 你的表 enable TRIGGER all

禁用所有表上的所有触发器

exec sp_msforeachtable &#39;ALTER TABLE ? DISABLE TRIGGER all&#39;

启用所有表上的所有触发器

exec sp_msforeachtable &#39;ALTER TABLE ? enable TRIGGER all&#39;

以上就是sql触发器怎么使用的详细内容,更多请关注 第一PHP社区 其它相关文章!


推荐阅读
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • MACElasticsearch安装步骤及验证方法
    本文介绍了MACElasticsearch的安装步骤,包括下载ZIP文件、解压到安装目录、启动服务,并提供了验证启动是否成功的方法。同时,还介绍了安装elasticsearch-head插件的方法,以便于进行查询操作。 ... [详细]
  • PHP玩家基地系统毕业设计(附源码、运行环境)的用户登录界面、游戏管理和玩家作品管理
    本文介绍了一个PHP玩家基地系统的毕业设计,包括用户登录界面、游戏管理和玩家作品管理等功能。附带源码和运行环境,并提供免费赠送本源代码和数据库的方式,请私信获取详细信息。摘要共计约XXX字。 ... [详细]
  • Monkey《大话移动——Android与iOS应用测试指南》的预购信息发布啦!
    Monkey《大话移动——Android与iOS应用测试指南》的预购信息已经发布,可以在京东和当当网进行预购。感谢几位大牛给出的书评,并呼吁大家的支持。明天京东的链接也将发布。 ... [详细]
  • 本文介绍了《中秋夜作》的翻译及原文赏析,以及诗人当代钱钟书的背景和特点。通过对诗歌的解读,揭示了其中蕴含的情感和意境。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 给定一个二叉树,要求随机选择树上的一个节点。解法:遍历树的过程中,随机选择一个节点即可。具体做法参看:从输入 ... [详细]
author-avatar
mobiledu2502887637
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有