触发器-- 肖敏_入门系列_数据库进阶 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 ...
随机推荐
- spctl命令返回的结果输入到文本中
说一下我遇到的问题. mac自动打包完之后上传到苹果商店公正,公正后需要检查一下公正的结果, spctl -a -v LBCast.app #查看是否公证成功 显示如下表示公证成功了,有Notar ...
- JS的数据类型、常量、变量、以及基本对象的知识总结
第一部分.JS的常见数据类型,特别要注意的是JS中大小写要求很严格,一定要注意字段大小写. 1.字符串(String) 举例: var cellname = "Bill Gate" ...
- Python基础笔记:input()输入与数据类型转换
input就是个万能输入,不过input输入的元素都是以str形式保存的,如果要他作为一个整数的话,就需要进行数据类型转换. input的使用 name=input('please input you ...
- 039-PHP使用闭包函数来进行父实例的变量自增,错误示例
<?php // 如何使用闭包函数来进行父实例的变量自增,错误示例 function demo(){ $num = 1; $func = function() use($num){ echo $ ...
- Codeforces 459C Pashmak and Buses 机智数学题
这个题目说的是有n个人,有k辆巴士,有m天,每天都要安排n个人坐巴士(可以有巴士为空),为了使得这n个人不会成为朋友,只要每两个人在这m天里坐的巴士至少一天不相同即可. 要你求是否有这样的安排方法,如 ...
- Java高级特性——注解,这也许是最简单易懂的文章了
最近,浪尖在做flink的项目时source和sink的绑定那块用到了注解,当然新版本1.6以后就变为server load的方式加载. 但是浪尖也是觉得很有毕业讲一下注解,毕竟高级免试也会问答的吧. ...
- C# Process类详解
C# Process类详解 Process[] processes = Process.GetProcessesByName(current.ProcessName); 根据进程名字找到所有进程,返回 ...
- leetcode 正则表达式 (动态规划)
给你一个字符串 s 和一个字符规律 p,请你来实现一个支持 '.' 和 '*' 的正则表达式匹配. '.' 匹配任意单个字符'*' 匹配零个或多个前面的那一个元素所谓匹配,是要涵盖 整个 字符串 s的 ...
- weex 随笔
1.三大模块: <template>:样板,内容区 <style>:css <script>: js <script> export default{ ...
- jquery获取高度
分为以下几种: .height() -获取匹配元素集合中的第一个元素的当前计算高度值 或 设置每一个匹配元素的高度值. -.css('height') 和 .height()之间的区别是后者返回一个没 ...