不知不觉讲到触发器了,一般我们做程序的很少接触到触发器,触发器的操作一般是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)的更多相关文章

  1. PL/SQL 07 触发器 trigger

    --触发器 触发器有三类: 数据操作触发器    用before触发器进行数据校验    用after触发器进行级联操作    语句触发器限制数据的操作和记录操作日志    instead of 触发 ...

  2. SQL入门(3):定义约束/断言assertion/触发器trigger

    本文介绍数据库的完整性 完整性控制程序: 指定规则,检查规则 (规则就是约束条件) 动态约束 intergrity constraint::=(O,P,A,R) O : 数据集合, 约束的对象 ?: ...

  3. MySQL数据库触发器(trigger)

    MySQL触发器(trigger):监视某种情况并触发某种操作 一:四要素 触发时间:before/after 地点:table 监视操作:insert/update/delete 触发操作:inse ...

  4. SQL Server 触发器

    触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 触发器对表进行插入.更新.删 ...

  5. mysql之触发器trigger

    触发器(trigger):监视某种情况,并触发某种操作. 触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/befo ...

  6. mysql之触发器trigger 详解

    为了梦想,努力奋斗! 追求卓越,成功就会在不经意间追上你 mysql之触发器trigger 触发器(trigger):监视某种情况,并触发某种操作. 触发器创建语法四要素:1.监视地点(table)  ...

  7. Oracle数据库编程:使用PL/SQL编写触发器

    8.使用PL/SQL编写触发器: 触发器存放在数据缓冲区中.        触发器加序列能够实现自动增长.        在触发器中不能使用connit和rollback.        DML触发器 ...

  8. mysql之触发器trigger(1)

    触发器(trigger):监视某种情况,并触发某种操作. 触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/befo ...

  9. sql server触发器的例子

    发布:thebaby   来源:脚本学堂     [大 中 小] 本文介绍下,在sql server数据库中使用触发器的简单例子,有需要的朋友可以参考下,希望对你有一定的帮助. 原文地址:http:/ ...

  10. 15、SQL Server 触发器

    SQL Server 触发器 触发器是一种特殊的存储过程,只有当试图用数据操作语言DML来修改数据时才会触发,DML包含对视图和表的增.删.改. 触发器分为DML触发器和DDL触发器,其中DML触发器 ...

随机推荐

  1. (转)为什么需要正则表达式 by 王珢

    为什么需要正则表达式 by 王垠 学习Unix最开头,大家都学过正则表达式(regexp).可是有没有人考虑过我们为什么需要正则表达式? 正则表达式本来的初衷是用来从无结构的字符串中提取信息,殊不知这 ...

  2. 基于zepto的H5/移动端tab切换触摸拖动加载更多数据

    以前实现移动端的滑动加载更多实现的方法是当滚动条快到页面底部时就自动加载更多的数据,在这方面很多人都用的是"西门的后花园"写的一个叫dropload的插件,这个插件用起来也很好,很 ...

  3. @autowired和@resource的区别

    @Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自 动注入罢了.@Resource有两个属性是比较重要的, ...

  4. (原).NET程序加入多语言包解决方案工具,超级棒

    Multi-Language Add-In Version 5.04.0088 for Visual Studio 2013 安装包:http://www.jollans.com/SetupMulti ...

  5. socket通信

    socket通信 一:socket基于Tcp连接,数据传输有保证 二:socket连接的建立过程: 1:服务器监听 2:客户端发出请求 3:建立连接 4:通信 三:一个简单的例子:服务器端每隔一段时间 ...

  6. tomcat相关

    一.下面这篇文章介绍了tomcat log相关内容 http://blog.csdn.net/cowmich/article/details/8173005

  7. 2016/11/17 周四 <javascript的封装简单示例>

    这是一个简单的javascript代码封装的示例以及封装后的调用方法: var ticker={ n:0, add:function() { this.n++; }, show:function() ...

  8. mysql 命令行还原备份数据库

    通常数据库还原备份可以通过navicat等数据库管理工具进行,只需要简单的导出导入就行了,但遇到有索引外键的数据库,数据库管理工具运行.sql文件会报错,这时候可以尝试命令行导入,亲测可以成功 MyS ...

  9. Html5选择本地视频音频文件播放

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  10. C#多线程介绍(下)

    转载原文:这里是链接内容 转载原文:这里写链接内容 转载原文:这里写链接内容 (重要事情说三遍) 引言 本文主要从线程的基础用法,CLR线程池当中工作者线程与I/O线程的开发,并行操作PLINQ等多个 ...