千家信息网

sql触发器如何使用

发表于:2025-01-24 作者:千家信息网编辑
千家信息网最后更新 2025年01月24日,这篇文章给大家分享的是有关sql触发器如何使用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。sql中的触发器是对某个表进行操作时而触发的某种条件,可以用CREATE语句创建
千家信息网最后更新 2025年01月24日sql触发器如何使用

这篇文章给大家分享的是有关sql触发器如何使用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

  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="" ddd="" declare="" purchasenum="" price="0,@ZpurchaseTotal=0" totalmoney="0,@purchaseNum" zpurchasetotal="" int="" select="" purchasenumber="JH" dopurchaseid="" dopurchasetime="" purchasetotal="" purchaseprice="" purchasestate="" purchasetype="" set="" jh20171031092322="" stockproductid="" dpurchaseprice="" curindex="1" rowcount="" otcount="" ptcount="" from="" table1="">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('[tempdb].[dbo].#PTable') IS NOT NULL --判断临时表#tmp是否存在,存在则删除   DROP TABLE #PTable   IF object_id('[tempdb].[dbo].#OTable') 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 'ALTER TABLE ? DISABLE TRIGGER all'

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

  exec sp_msforeachtable 'ALTER TABLE ? enable TRIGGER all'

感谢各位的阅读!关于"sql触发器如何使用"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

触发器 产品 采购 查询 条件 语句 生成 内容 数量 更多 篇文章 自动生成 订单 金额 不错 实用 特殊 一行 下限 也就是 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 天津一橙网络技术有限公司 2001年互联网科技泡沫 sql重建数据库索引 人保财险软件开发中心 新疆网络安全管理条例 网络安全的概念作文 网络技术可以当消防工程师吗 rust枪械数据库 网络安全专家会议纪要 软件开发总经理面试会问什么 广东电子软件开发公司 网络安全主题书法比赛绍兴 埃尔文海耶斯NBA数据库 中国网络安全法治建设之路 易利购系统软件开发 西城区信息化软件开发包括什么 做一个卖房的数据库管理系统 中国基站服务器的芯片是华为的吗 修改数据库时间列的时间 江苏服务器机柜质量好不好 软件开发阶段需要写的文档 推广网络技术咨询软件 哪些软件可以搭建私有服务器 数据库修改玩家信息 数据库优化 缓存 计算机网络技术偏理科 广州引力科技网络技术有限公司 电脑邮箱服务器设置教程 怎么开机禁止服务器管理器 银行oracle数据库维护费用
0