机房收费系统之触发器

印象里边最早接触触发器是在耿建玲的视频里边见到的,可是全然不理解,可是在实现机房收费系统的时候,就发现原来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]<span style="white-space:pre">	</span>--创建触发器
<span style="white-space:pre">			</span>
ON [dbo].[T_Recharge]<span style="white-space:pre">			</span>--在T_ReCharge表

for insert<span style="white-space:pre">				</span>为了插入数据而须要运行的操作

AS 
--定义一些參数
declare @cardID char(10)<span style="white-space:pre">	</span>--卡号
declare @cash decimal(10, 2)<span style="white-space:pre">	</span>--卡内剩余金额
declare @addmoney decimal(10, 2)<span style="white-space:pre">	</span>--充值金额
if UPDATE(cash)

BEGIN
	select @cardID =CardID  from inserted <span style="white-space:pre">	</span>--选择充值表中的卡号	
	select @addmoney=cash  from inserted --选择我们充值表中的充值金额
	select @cash =T_card.cash  from T_Card <span style="white-space:pre">	</span>--选择卡内的剩余金额
	update T_Card  set Cash=@cash+@addmoney  where cardID =@cardID 
END
</span>

这里我们大家解释一下。这个流程是怎么回事,首先我们要运行的语句就是insert Recharge_Info into (cardID,addMoney...) values(@cardID,addMoney...),那么触发器当你在插入数据的时候,就会将信息保存到Inserted中,然后我们再依据须要把里边的数据取出来。用来更新我们须要更新的表。
在触发器中,我们有两张表。一张是deleted表。一张Inserted表。这两张是虚拟表,用用完之后数据库会自己主动删除。
以下我用表格的形式将他们的用处展现出来

对表的操作

Inserted逻辑表

Deleted逻辑表

添加记录(insert)

存放添加的记录

删除记录(delete)

存放被删除的记录

改动记录(update)

存放更新后的记录

存放更新前的记录


所以我们在运行操作的时候,人们会说触发器是同一时候操作的。事实上不是的,触发器把我们前边说的insert Recharge_Info into (cardID,addMoney...) values(@cardID,addMoney...。Update Student_Info set Cash=Cash+addMoney where cardID=@cardID 自己把逻辑问题给结局了,从而省的我们再写两仅仅三条语句去组合,用一次还好。那么用多次呢?
但是触发器也不是越多越好,由于他是体如今数据库中的一段代码,不会呈如今程序中,所以这在开发的阶段加几个或许不是问题。但是假设要是以后咱们的系统出现故障了。那么要改动这方面就显得有点难了,触发器越是多越是会造成逻辑上的困难,所以建议大家用能够,适当的用。

最后为大家献上创建各种触发器的一些小Demo
Insert触发器
create trigger tgr_classes_insert
	on classes
    	for insert --插入触发
	as
    --定义变量
    declare @id int, @name varchar(20), @temp int;
    --在inserted表中查询已经插入记录信息
    select @id = id, @name = name from inserted;
    set @name = @name + convert(varchar, @id);
    set @temp = @id / 2;    
    insert into student values(@name, 18 + @id, @temp, @id);
delete触发器
create trigger tgr_classes_delete
on classes
    for delete --删除触发
as
    print '备份数据中……';    
    if (object_id('classesBackup', 'U') is not null)
        --存在classesBackup,直接插入数据
        insert into classesBackup select name, createDate from deleted;
    else
        --不存在classesBackup创建再插入
        select * into classesBackup from deleted;
    print '备份数据成功!

'

; update触发器
create trigger tgr_classes_update
    on classes
    for update
   as
    declare @oldName varchar(20), @newName varchar(20);
    --更新前的数据
    select @oldName = name from deleted;
    if (exists (select * from student where name like '%'+ @oldName + '%'))
        begin
            --更新后的数据
            select @newName = name from inserted;
            update student set name = replace(name, @oldName, @newName) where name like '%'+ @oldName + '%';
            print '级联改动数据成功!

'

; end else print '无需改动student表!

'

; 一个触发器,一个存储过程。一个全自己主动。一个随意调用,都能让程序执行的更快,占用的资源更少。虽然看上去也非常像。功能貌似给我们降低了非常多的压力,可是在写的时候。或者说是在设计数据库的时候,我们还是要慎重的用,否者我们会给软件以后的执行带来难以想象的痛苦。

转载于:https://www.cnblogs.com/lytwajue/p/6731908.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值