触发器-- 肖敏_入门系列_数据库进阶 60、触发器(三) --youku


https://v.youku.com/v_show/id_XMzkxOTc5NDY0OA==.html?spm=a2h0k.11417342.soresults.dtitle

https://v.youku.com/v_show/id_XMzkyMTM1MDMxNg==.html?spm=a2h0k.11417342.soresults.dtitle

CREATE TRIGGER v_entity_trg_u
ON v_entity
FOR update
AS
declare @old_file_id id_TY, @new_file_id id_TY, @old_file_line int, @new_file_line int
select @old_file_id = file_id, @old_file_line = file_line from deleted
select @new_file_id = file_id , @new_file_line = file_line from inserted
IF @old_file_id ! = @new_file_id OR @old_file_line != @new_file_line
BEGIN
insert into v_entity_hist (ent_id, action, file_id, file_line, last_chg_dt)
select ent_id, action, file_id, file_line, last_src_dt from deleted
END
1.
银行信息表account,交易信息表transinfo,现增加一笔交易记录
则account表账户余额应该变化
2.
这两个过程是一个整体,要么都执行,要么都不执行
begin transaction
向交易信息表插入数据
在账户表中修改数据
Commit transaction
如果失败
Rollback transaction

触发器:只要用户向交易信息表中插入了数据,系统会自动在账户表中修改数据
自动执行,整个过程是一个事务

Create TRIGGER trigger_name
ON table_name [with encryption]
FOR {[insert/update/delete]}
AS
SELECT sentence
GO
------------------------------------eg--------------
id从一万开始
create table Account
(
id int identity(10000, 1) primary key,
name nvarchar(16) not null,
balance int not null,---money left
)
create table TransInfo
(
id int identity(1, 1) primary key,
accountId int not null,
[type] int not null, -- 1 deposit 0 withdraw
amount int not null,
createDatetime datetime not null
)
alter table TransInfo -- 建立约束
add constraint FK_ACCOUNTID foreign key (accountId)
references Account(id);

insert into dbo.Account
select '郭靖' 5000 union
select '黄蓉' 10000

--针对新增交易记录,修改账户表的余额
create trigger tg_transinfo_insert
on TransInfo
for insert
as
--需要从新插入的数据中,取出交易数据
--账户编号,交易金额,交易类型
--系统有2临时表:inserted 存放最新加入的数据
--deleted 存放被删除的或被修改的原始数据
declare @accId int, @amount int, @type int
select @accId=accountId, @type=type, @amount=amount
from inserted --拿到新加入的数据

if(@type = 0)
begin
set @amount = @amount * -1;
end
update Account
set balance = balance + @amount
where id = @accId
go
触发器不用手动调用
当insert会自动调用
insert into TransInfo
select 10000, 0, 100, GETDATE()

declare @old_file_id id_TY, @new_file_id id_TY, @old_file_line int, @new_file_line int
select @old_file_id = file_id, @old_file_line = file_line from deleted
select @new_file_id = file_id , @new_file_line = file_line from inserted
IF @old_file_id ! = @new_file_id OR @old_file_line != @new_file_line
BEGIN
insert into v_entity_hist (ent_id, action, file_id, file_line, last_chg_dt)
select ent_id, action, file_id, file_line, last_src_dt from deleted
END































优质内容筛选与推荐>>
1、客户端静态页面玩分页(转载)
2、Windows Error Code(windows错误代码详解)
3、个人项目总结 By 钟华平
4、键盘输入输出
5、python基础之初始函数


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号