机房收费系统之触发器
程序员文章站
2022-05-29 21:07:43
...
印象里边最早接触触发器是在耿建玲的视频里边见到的,但是完全不理解,但是在实现机房收费系统的时候,就发现原来SQL Server中还有这么一个强大的功能,简直是和存储过程合称为最佳兄弟二人组。 首先我们看看触发器是什么? 触发器,因为我先认识的存储过程+
印象里边最早接触触发器是在耿建玲的视频里边见到的,但是完全不理解,但是在实现机房收费系统的时候,就发现原来SQL Server中还有这么一个强大的功能,简直是和存储过程合称为最佳兄弟二人组。
首先我们看看触发器是什么?
触发器,因为我先认识的存储过程+事务,所以我在这里把他称为存储过程的小兄弟,至于为什么,因为他们真的很像,对于存储过程,大家可以在http://blog.csdn.net/lovemenghaibin/article/details/38235817了解,这里就不详细的介绍了,但是触发器是什么呢?
触发器是SQL Server提供给程序员和数据分析员来保证数据完整性的一种方式,它就是与表事件相关的特殊存储过程。触发器不能被直接执行,只能为表上的Insert\Update\Delete事件所触发。它也不能传递或接受参数。
触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于强制服从复杂的业务规则或要求。例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。 比如说,我这里有两张表,一张是充值表(Recharge_Info),一张是学生表(Student_Info),如果我们要进行充值行为,也就是要进行两个动作,第一为学生表的钱加上充值的钱,第二就是为充值表里边添加一条记录,那么如果要完成这个操作,我们需要两步,更新和插入信息,也就说我们会这样 insert Recharge_Info into (cardID,addMoney...) values(@cardID,addMoney...) Update Student_Info set Cash=Cash+addMoney where cardID=@cardID这个过程如果需要执行多次呢,大家每次都要用两条语句来组合这一个过程,是不是麻烦了点,于是现在就有了触发器这个过程,那么我来为大家来展示一下触发器的相同实现。
CREATE TRIGGER [dbo].[TR_charge_U] --创建触发器 ON [dbo].[T_Recharge] --在T_ReCharge表 for insert 为了插入数据而需要执行的操作 AS --定义一些参数 declare @cardID char(10) --卡号 declare @cash decimal(10, 2) --卡内余额 declare @addmoney decimal(10, 2) --充值金额 if UPDATE(cash) BEGIN select @cardID =CardID from inserted --选择充值表中的卡号 select @addmoney=cash from inserted --选择我们充值表中的充值金额 select @cash =T_card.cash from T_Card --选择卡内的余额 update T_Card set Cash=@cash+@addmoney where cardID =@cardID END