触发器实例讲解(二)

 

接(一)

--触发器示例2

/*

创建触发器[T_INSERT_卷烟销售表],该触发器较复杂。

说明: 每当[卷烟库存表]发生 INSERT 动作,则引发该触发器。

触发器功能: 实现业务规则。

业务规则: 如果销售的卷烟品牌不存在库存或者库存为零,则返回错误。

否则则自动减少[卷烟库存表]中对应品牌卷烟的库存数量和库存金额。

*/

IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = ’TR’ AND NAME = ’T_INSERT_卷烟销售表’)

DROP TRIGGER T_INSERT_卷烟销售表

GO

CREATE TRIGGER T_INSERT_卷烟销售表

ON 卷烟销售表

FOR INSERT

AS

BEGIN TRANSACTION

--检查数据的合法性:销售的卷烟是否有库存,或者库存是否大于零

IF NOT EXISTS (

SELECT 库存数量

FROM 卷烟库存表

WHERE 卷烟品牌 IN (SELECT 卷烟品牌 FROM INSERTED)

)

BEGIN

--返回错误提示

RAISERROR(’错误!该卷烟不存在库存,不能销售。’,16,1)

--回滚事务

ROLLBACK

RETURN

END

IF EXISTS (

SELECT 库存数量

FROM 卷烟库存表

WHERE 卷烟品牌 IN (SELECT 卷烟品牌 FROM INSERTED) AND

库存数量 <= 0

)

BEGIN

--返回错误提示

RAISERROR(’错误!该卷烟库存小于等于0,不能销售。’,16,1)

--回滚事务

ROLLBACK

RETURN

END

--对合法的数据进行处理

--强制执行下列语句,保证业务规则

UPDATE 卷烟销售表

SET 销售金额 = 销售数量 * 销售单价

WHERE 卷烟品牌 IN (SELECT 卷烟品牌 FROM INSERTED)

DECLARE @卷烟品牌 VARCHAR(40)

SET @卷烟品牌 = (SELECT 卷烟品牌 FROM INSERTED)

DECLARE @销售数量 MONEY

SET @销售数量 = (SELECT 销售数量 FROM INSERTED)

UPDATE 卷烟库存表

SET 库存数量 = 库存数量 - @销售数量,

库存金额 = (库存数量 - @销售数量)*库存单价

WHERE 卷烟品牌 = @卷烟品牌

COMMIT TRANSACTION

GO

--请大家自行跟踪[卷烟库存表][卷烟销售表]的数据变化。

--针对[卷烟销售表],插入第一条测试数据,该数据是正常的。

INSERT INTO 卷烟销售表(卷烟品牌,购货商,销售数量,销售单价,销售金额)

SELECT ’红塔山新势力’,’某购货商’,10,12,1200

GO

--针对[卷烟销售表],插入第二条测试数据,该数据 销售金额 不等于 销售单价 * 销售数量。

--触发器将自动更正数据,使 销售金额 等于 销售单价 * 销售数量。

INSERT INTO 卷烟销售表(卷烟品牌,购货商,销售数量,销售单价,销售金额)

SELECT ’红塔山人为峰’,’某购货商’,10,22,2000

GO

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值