T-Sql(六)触发器(trigger)
不知不觉讲到触发器了,一般我们做程序的很少接触到触发器,触发器的操作一般是DB人员来完成。
然而有的时候一些简单的业务需要我们自己去完成,不能每次都去麻烦DB人员,所以说,编程人员要全才,除了编程以为的专业知识也要涉猎,比如js,css,html,t-sql等一些语法,不一定要去精通,但是要熟悉,至少语法可以看懂,这样对我们的编程有事半功倍的效果,出现异常错误,我们也方便调试,以便最快找出错误。
言归正传,什么事触发器,顾名思义,就是你做一个操作,就会触发另一个事件,去执行一些操作。
比如你点烟花,点是一个动作,烟花是另一个动作,点动作完成就会触发烟花这个动作。
还有就是触发器必须依附一个主体,比如依附于某一张表,就像编程中事件这个概念。
下面我们通过一个简单的实例,和大家一步一步的来理解和运用触发器。
实例要求:
1,建商品表(Store),订单表(orders),日志表(Logs)
2,创建订单表插入触发器,实现插入一条订单信息,商品表中商品数量相应减少,订单中的总金额相应增加。
3,创建订单表更新触发器,实现更新一条订单信息,商品表中商品数量相应变化,订单中的总金额相应变化。(和2类似)
4,创建日志表触发器,实现更新商品表价格变化情况。
1,创建商品表(Store),订单表(orders),日志表(Logs)
第一步没什么讲解,我们创建表,并加一些示例数据。
示例代码:
create table Store
(
ID uniqueidentifier primary key,
ProductID int not null,
ProductPrice money not null default 1,
ProductCH nvarchar(80) not null,
ProductDate datetime not null,
NowNumber int not null
);
create table orders
(
OrderID int primary key,
ProductID int not null,
BuyNumber int Not null default 1,
BuyPricr money not null,
NowOrderPrice money default 0
)
create table Logs
(
ID uniqueidentifier primary key,
operatedatetime datetime,
ProductID int,
oldprice money,
newprice money
); insert into dbo.Store
values(NEWID(),1001,5000,'联想','2011-9-1',50)
insert into dbo.Store
values(NEWID(),1002,6000,'apple','2011-9-1',50)
insert into dbo.orders(OrderID,ProductID,BuyNumber,BuyPricr)
values(10013,1001,5,6000)
2,创建订单表触发器
要求2,3类似操作我在一起讲解了。
先看示例代码:
create trigger tri_order_NowOrderPrice
on orders after insert
as
begin
declare @NowOrderPrice money;
declare @BuyNumber int;
declare @ProductID int;
select @ProductID= ProductID,@BuyNumber= BuyNumber from inserted;
select @NowOrderPrice=inserted.BuyNumber * inserted.BuyPricr from inserted;
update orders set NowOrderPrice=@NowOrderPrice where ProductID=@ProductID;
update Store set NowNumber=NowNumber-@BuyNumber where ProductID=@ProductID;
end; create trigger tri_store_NowOrderPrice2
on orders after update
as
begin
declare @NowOrderPrice money;
declare @ProductID int;
declare @BuyNumber1 int;
declare @BuyNumber2 int;
select @ProductID= ProductID from inserted;
select @BuyNumber1=BuyNumber from inserted;
select @NowOrderPrice=inserted.BuyNumber * inserted.BuyPricr from inserted;
select @BuyNumber2=deleted.BuyNumber from deleted where ProductID=@ProductID;
update orders set NowOrderPrice=@NowOrderPrice where ProductID=@ProductID;
update Store set NowNumber=NowNumber-(@BuyNumber1-@BuyNumber2) where ProductID=@ProductID;
end;
触发器的关键字是trigger,语法是,on 表名 after 操作名称(一般为insert,update,delete),begin end中写一些触发器的处理操作。
inserted获取insert之后的数据。语法就是这么简单。
3,创建日志表触发器
日志表触发器要做的操作就是记录商品价格变化,那对应就应该在商品表中创建触发器。
示例代码:
create trigger tri_NowOrderPrice4
on dbo.Store after insert,update,delete
as
begin
if exists(select *from inserted) and exists(select *from deleted)
begin
print('update');
declare @price1 money;
declare @price2 money;
declare @datetime datetime;
select @price1=ProductPrice from deleted;
select @price2=ProductPrice from inserted;
if @price1!=@price2
begin
declare @ProductID int;
select @ProductID=ProductID from inserted
insert into Logs(ID,operatedatetime,ProductID,oldprice,newprice)
values(newid(),convert(datetime,getdate()),@ProductID,@price1,@price2) select *from dbo.Logs
end
end
else if exists(select *from inserted)
begin
print('insert');
end
else if exists(select *from deleted)
begin
print('delete');
end
else
begin
print('others');
end
end
触发器就是这些内容,有关触发器的一些复杂操作希望大家有时间研究下,讲的不好请大家多多指正,希望大家学好t-sql语言。
以后继续整理编程相关内容,希望大家多多关注。。。。
T-Sql(六)触发器(trigger)的更多相关文章
- PL/SQL 07 触发器 trigger
--触发器 触发器有三类: 数据操作触发器 用before触发器进行数据校验 用after触发器进行级联操作 语句触发器限制数据的操作和记录操作日志 instead of 触发 ...
- SQL入门(3):定义约束/断言assertion/触发器trigger
本文介绍数据库的完整性 完整性控制程序: 指定规则,检查规则 (规则就是约束条件) 动态约束 intergrity constraint::=(O,P,A,R) O : 数据集合, 约束的对象 ?: ...
- MySQL数据库触发器(trigger)
MySQL触发器(trigger):监视某种情况并触发某种操作 一:四要素 触发时间:before/after 地点:table 监视操作:insert/update/delete 触发操作:inse ...
- SQL Server 触发器
触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 触发器对表进行插入.更新.删 ...
- mysql之触发器trigger
触发器(trigger):监视某种情况,并触发某种操作. 触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/befo ...
- mysql之触发器trigger 详解
为了梦想,努力奋斗! 追求卓越,成功就会在不经意间追上你 mysql之触发器trigger 触发器(trigger):监视某种情况,并触发某种操作. 触发器创建语法四要素:1.监视地点(table) ...
- Oracle数据库编程:使用PL/SQL编写触发器
8.使用PL/SQL编写触发器: 触发器存放在数据缓冲区中. 触发器加序列能够实现自动增长. 在触发器中不能使用connit和rollback. DML触发器 ...
- mysql之触发器trigger(1)
触发器(trigger):监视某种情况,并触发某种操作. 触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/befo ...
- sql server触发器的例子
发布:thebaby 来源:脚本学堂 [大 中 小] 本文介绍下,在sql server数据库中使用触发器的简单例子,有需要的朋友可以参考下,希望对你有一定的帮助. 原文地址:http:/ ...
- 15、SQL Server 触发器
SQL Server 触发器 触发器是一种特殊的存储过程,只有当试图用数据操作语言DML来修改数据时才会触发,DML包含对视图和表的增.删.改. 触发器分为DML触发器和DDL触发器,其中DML触发器 ...
随机推荐
- centos7 解决ftp和apache运行目录权限冲突问题
1.将ftp用户加入到apache用户组 usermod -a -G apache ftpadmin ftpadmin 为ftp用户 2.设置网站根目录/var/www的所有组为apache chow ...
- (转)win7 64 安装mysql-python:_mysql.c(42) : fatal error C1083: Cannot open include file: 'config-win.h': No such file or directory
原文地址:http://www.cnblogs.com/fnng/p/4115607.html 作者:虫师 今天想在在win7 64位环境下使用python 操作mysql 在安装MySQL-pyth ...
- Openssl生成证书三板斧
证书创建三步曲: 一.密钥文件 二.请求文 三.根证书签名 最后看需要是否合并证书文件 1. 创立根证书密钥文件(自己做CA)root.key: [kk@test ~]$ openssl genrsa ...
- PHP基础面试题
1.PHP的意思? 答:PHP是一个基于服务端来创建动态网站的脚本语言,您可以用PHP和HTML生成网站主页 2.谈谈asp,php,jsp的优缺点? 答:ASP全名Active Server Pag ...
- Kafka设计解析(二)- Kafka High Availability (上)
本文转发自Jason’s Blog,原文链接 http://www.jasongj.com/2015/04/24/KafkaColumn2 摘要 Kafka在0.8以前的版本中,并不提供High Av ...
- myeclipse中导入js报如下错误Syntax error on token "Invalid Regular Expression Options", no accurate correc
今天在使用bootstrap的时候引入的js文件出现错误Syntax error on token "Invalid Regular Expression Options", no ...
- ABP理论学习之发布说明
返回总目录 查看更详细信息以及下载源代码请查看原文档 ABP v0.9.2.0 | [更新日期:2016/6/6 11:21:28 ] 解决方案转换成xproj/project.json格式. 添加了 ...
- Java NIO5:选择器1---理论篇
选择器 最后,我们探索一下选择器.由于选择器内容比较多,所以本篇先偏理论地讲一下,后一篇讲代码,文章也没有什么概括.总结的,写到哪儿算哪儿了,只求能将选择器写明白,并且将一些相对重要的内容加粗标红. ...
- 《Entity Framework 6 Recipes》中文翻译系列 (18) -----第三章 查询之结果集扁平化和多属性分组
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 3-14 结果集扁平化 问题 你有一对多关联的两个实体,你想通过一个查询,获取关联 ...
- LInux MySQL 数据库 的一些操作
数据库安装: ………… 创建数据库连接新用户: 1.登录mysql #mysql -u root -p 2.新增用户 insert into mysql.user(Host,User,Password ...