触发器-- 肖敏_入门系列_数据库进阶 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
触发器-- 肖敏_入门系列_数据库进阶 60、触发器(三) --youku的更多相关文章
- Hadoop MapReduce编程 API入门系列之压缩和计数器(三十)
不多说,直接上代码. Hadoop MapReduce编程 API入门系列之小文件合并(二十九) 生成的结果,作为输入源. 代码 package zhouls.bigdata.myMapReduce. ...
- Java入门系列之StringBuilder、StringBuffer(三)
前言 上一节我们讲解了字符串的特性,除了字符串类外,还有两个我们也会经常用到的类,那就是StringBuffer和StringBuilder.因为字符串不可变,所以我们每次对字符串的修改比如通过连接c ...
- 【Lucene3.6.2入门系列】第04节_中文分词器
package com.jadyer.lucene; import java.io.IOException; import java.io.StringReader; import org.apach ...
- 【Lucene3.6.2入门系列】第05节_自定义停用词分词器和同义词分词器
首先是用于显示分词信息的HelloCustomAnalyzer.java package com.jadyer.lucene; import java.io.IOException; import j ...
- 【Lucene3.6.2入门系列】第03节_简述Lucene中常见的搜索功能
package com.jadyer.lucene; import java.io.File; import java.io.IOException; import java.text.SimpleD ...
- GEF入门实例_总结_04_Eclipse插件启动流程分析
一.前言 本文承接上一节:GEF入门实例_总结_03_显示菜单和工具栏 注意到app目录下的6个类文件. 这6个文件对RCP应用程序而言非常重要,可能我们现在对这几个文件的理解还是云里雾里,这一节我们 ...
- 使用Java管理千台规模Linux服务器_入门
http://www.oschina.net/code/snippet_222919_11734 代码分享 当前位置: 代码分享 » Java » 网络编程 搜 索 [饶过] 使用Java管理千 ...
- [转载]WCF系列_分布式事务(下)
浏览到chnking的WCF的分布式事务处理不错,转载过来分享一下. 1. WCF分布式事务例子这里也用转账的例子说事.用户在系统A和系统B都有账户,账户间的资金可以互转,系统A的资金减少多少,系统B ...
- ArcGIS for Desktop入门教程_第七章_使用ArcGIS进行空间分析 - ArcGIS知乎-新一代ArcGIS问答社区
原文:ArcGIS for Desktop入门教程_第七章_使用ArcGIS进行空间分析 - ArcGIS知乎-新一代ArcGIS问答社区 1 使用ArcGIS进行空间分析 1.1 GIS分析基础 G ...
随机推荐
- 如何禁用AD OU 下面的邮箱用户的Exchange ActiveSync 和 适用于设备的OWA
Get-Mailbox -OrganizationalUnit QQ禁用名单 | Set-CASMailbox -ActiveSyncEnabled $false -OWAforDevicesEna ...
- dede调出所有栏目以及栏目下的二级栏目
1.调出所有栏目以及栏目下的二级栏目 {dede:channelartlist typeid='top'}<a href="{dede:field name='typeurl'/}&q ...
- nginx的日志切换
#touch /usr/local/nginx/sbin/cut_nginx_log.sh #chmod 755 /usr/local/nginx/sbin/cut_nginx_log.sh 下面是 ...
- 【WPF学习】第二十四章 基于范围的控件
WPF提供了三个使用范围概念的控件.这些控件使用在特定最小值和最大值之间的数值.这些控件——ScrollBar.ProgressBar以及Slider——都继承自RangeBase类(该类又继承自Co ...
- [NOIP2017] T4 跳房子 DP+二分
Description 跳房子,也叫跳飞机,是一种世界性的儿童游戏,也是中国民间传统的体育游戏之一.跳房子的游戏规则如下: 在地面上确定一个起点,然后在起点右侧画 n 个格子,这些格子都在同一条直线 ...
- 启用sql日志
SHOW VARIABLES LIKE "general_log%"; -- 查询是否启用日志 SET GLOBAL general_log = 'ON'; -- 设置启用 SE ...
- jquery实现搜索框从中间向两边扩展(左右放大)
显示效果: 隐藏效果: 前端核心代码如下: <div class="search-icon col-md-2 col-sm-2 col-xs-4 col-md-offset-5 col ...
- DataStructuresAndAlogorithm--红黑树
简介 为了理解红黑树(red-black tree)是什么,首先需要知道二叉树. 定义1:二叉树是结点的有限集合,该集合或者为空集,或者是由一个根和两棵互不相交的,称为该根的左子树和右子树的二叉树组成 ...
- EUI库 - 概述
新特性 36k 访问EUI组件宽高时,也会跟原生显示对象的表现一致,立即能得到包含子项的宽高值 统一的显示列表 普通对象和eui对象都可用addChild来添加 一个逻辑组件只管 ...
- Spring AOP 基本的使用
1. jar包 2.全局配置文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=&q ...