设为首页 加入收藏

TOP

SQL视图、局部变量、全局变量、条件语句、事务和触发器简析(二)
2014-11-24 02:47:21 来源: 作者: 【 】 浏览:3
Tags:SQL 视图 局部 变量 全局 条件 语句 事务 触发器 简析
set @ersum=0
update bank set MeMoney=MeMoney-1000 where ID=me ---从我卡里扣掉1000
set @ersum=@ersum+@@ERROR --如果不出错这里还是0,如果错了,这里将不是0
update bank set HeMoney=HeMoney+100 where ID=he ---给我朋友卡里加上1000
set @ersum=@ersum+@@ERROR --如果这里的结果是0将表明没有出错
if(@ersum<>0) --true有错,false没错
begin
rollback tran ---回滚事务
end
else
begin
commit tran --执行事务
end
六.触发器
1.触发器,当数据库中的表有所改动(添删改)是会触发一中事件,这样一种机制,就是触发器。
2.触发器种类:after跟for一样,是语句执行完毕后触发事件。instead of :本来你要执行一种操作,结果执行了另外一种操作,原本要执行的操作被替换。
3.触发器的创建
create trigger 触发器名 on 操作表(实际要操作的表)
for|after|instead of --选其任意一种类型,其中for跟after是一样的
update|delete|insert --原本要执行哪一种动作
as www.2cto.com
sql语句..... ---你想要执行的sql语句
4.触发器的小案例
--这个例子是,删除Tb1里面的数据,把删除的数据同时备份到Tb1Bak表中
create trigger tri_bak on Tb1 --声明一个tri_bak ,如果Tb1表中的数据变化触发这个触发器
after delete ---删除完成后执行下面的操作
as
insert into Tb1Bak select * from deleted ---这里的deleted是系统自动生成的表,存放为上一次的数据库表中删除的数据。
5.小知识点:数据更新插入删除的过程为,插入数据库表的同时,也插入了系统表的insert表,删除的同时把删除的这条数据插入到了deleted表中,跟新的同时,deleted表中插入就数据,insert表中也添加了新数据。 我这里的insert 、deleted表都为系统自动生成的,不是我们操作的表。

作者 张龙豪
首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇教你使用MySQL触发器自动更新memc.. 下一篇浅谈存储过程和触发器

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: