范文健康探索娱乐情感热点
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

sql触发器(sql数据库触发器怎么写)

  sql 触发器(sql数据库触发器怎么写)
  触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。
  一、触发器的优点
  1.触发器是自动的。当对表中的数据做了任何修改之后立即被激活。
  2.触发器可以通过数据库中的相关表进行层叠修改。
  3.触发器可以强制限制。这些限制比用CHECK约束所定义的更复杂。与CHECK约束不同的是,触发器可以引用其他表中的列。二、触发器的分类
  SqlServer包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。
  1.DML(数据操作语言,Data Manipulation Language)触发器
  DML触发器是一些附加在特定表或视图上的操作代码,当数据库服务器中发生数据操作语言事件时执行这些操作。SqlServer中的DML触发器有三种:
  insert触发器:向表中插入数据时被触发;
  delete触发器:从表中删除数据时被触发;
  update触发器:修改表中数据时被触发。
  当遇到下列情形时,应考虑使用DML触发器:
  通过数据库中的相关表实现级联更改
  防止恶意或者错误的insert、update和delete操作,并强制执行check约束定义的限制更为复杂的其他限制。
  评估数据修改前后表的状态,并根据该差异才去措施。
  2.DDL(数据定义语言,Data Definition Language)触发器
  DDL触发器是当服务器或者数据库中发生数据定义语言(主要是以create,drop,alter开头的语句)事件时被激活使用,使用DDL触发器可以防止对数据架构进行的某些更改或记录数据中的更改或事件操作。
  3.登录触发器
  登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。三、触发器的工作原理
  [DELETE, INSERT, UPDATE]对应为当执行删除、插入、更新三种动作时被触发
  执行insert时,获取插入后的数据,可用select*from inserted读取
  执行delete时,获取删除前的数据,可用select*from deleted读取
  执行update时,获取更新前的数据,可用select*from deleted读取,获取更新后数据,可用select*from inserted读取
  四、创建触发器
  1、创建触发器的语法:CREATETRIGGERtrigger_name  ONtable_name  [WITHENCRYPTION]  FOR|AFTER|INSTEADOF[DELETE,INSERT,UPDATE]  AS  T-SQL语句  GO  --withencryption表示加密触发器定义的sql文本  --delete,insert,update指定触发器的类型
  2、创建insert触发器--创建insert触发器  createtriggertrig_insert  onstudent  afterinsert  as  begin  ifobject_id(N'student_sum',N'U')isnull--判断student_sum表是否存在  createtablestudent_sum(stuCountintdefault(0));--创建存储学生人数的student_sum表  declare@stuNumberint;  select@stuNumber=count(*)fromstudent;  ifnotexists(select*fromstudent_sum)--判断表中是否有记录  insertintostudent_sumvalues(0);  updatestudent_sumsetstuCount=@stuNumber;--把更新后总的学生数插入到student_sum表中  end  --测试触发器trig_insert-->功能是向student插入数据的同时级联插入到student_sum表中,更新stuCount  --因为是后触发器,所以先插入数据后,才触发触发器trig_insert;  insertintostudent(stu_name,stu_gender,stu_age)values('吕布','男',30);  selectstuCount学生总人数fromstudent_sum;  insertintostudent(stu_name,stu_gender,stu_age)values('貂蝉','女',30);  selectstuCount学生总人数fromstudent_sum;  insertintostudent(stu_name,stu_gender,stu_age)values('曹阿瞒','男',40);  selectstuCount学生总人数fromstudent_sum;
  3、创建delete触发器
  用户执行delete操作,就会激活delete触发器,从而控制用户能够从数据库中删除数据记录,触发delete触发器后,用户删除的记录会被添加到deleted表中,原来表的相应记录被删除,所以在deleted表中查看删除的记录。--创建delete触发器  createtriggertrig_delete  onstudent  afterdelete  as  begin  selectstu_idas已删除的学生编号,stu_namestu_gender,stu_age  fromdeleted  end;  --执行一一条delete语句触发trig_delete触发器  deletefromstudentwherestu_id=1;
  4、创建UPDATE触发器
  update触发器是当用户在指定表上执行update语句时被调用被调用,这种类型的触发器用来约束用户对数据的修改。update触发器可以执行两种操作:更新前的记录存储在deleted表中,更新后的记录存储在inserted表中。--创建update触发器  createtriggertrig_update  onstudent  afterupdate  as  begin  declare@stuCountint;  select@stuCount=count(*)fromstudent;  updatestudent_sumsetstuCount=@stuCount;  selectstu_idas更新前学生编号,stu_nameas更新前学生姓名fromdeleted  selectstu_idas更新后学生编号,stu_nameas更新后学生姓名frominserted  end  --创建完成,执行一条update语句触发trig_update触发器  updatestudentsetstu_name='张飞'wherestu_id=2;五、管理触发器
  1.查看触发器
  (1).查看数据库中所有的触发器--查看数据库中所有的触发器  use数据库名  go  select*fromsysobjectswherextype='TR'
  sysobjects 保存着数据库的对象,其中 xtype 为 TR 的记录即为触发器对象。在 name 一列,我们可以看到触发器名称。
  (2).sp_helptext 查看触发器内容use数据库名  go  execsp_helptext'触发器名称'
  将会以表的样式显示触发器内容。
  除了触发器外,sp_helptext 还可以显示 规则、默认值、未加密的存储过程、用户定义函数、视图的文本。
  (3).sp_helptrigger 用于查看触发器的属性
  sp_helptrigger 有两个参数:第一个参数为表名;第二个为触发器类型,为 char(6) 类型,可以是 INSERT、UPDATE、DELETE,如果省略则显示指定表中所有类型触发器的属性。

中国名小吃(10个最诱人的中国小吃)中国名小吃(10个最诱人的中国小吃)今年的国庆节和以往不同,不能免费欣赏朋友圈里来自全世界各地的景点和千姿百态的打卡照,大家只能在国内蹲。所以广东四川南京厦门,这几个国内热门旅游目南京书店(南京值得一去的9家书店)南京书店(南京值得一去的9家书店)2月初整理了一份深圳值得一去的独立书店,最近又发布了杭州北京郑州的独立书店盘点,很多人表示喜欢(如果你还没看过,可以回复书店查看)。这是一个系列计重庆打黑视频(重庆十大黑道大哥排名)重庆打黑视频(重庆十大黑道大哥排名)重庆日报20210514105244本报首席记者黄乔南岸区公安分局开展扫黑除恶集中清查统一行动。(市委政法委供图)这是一场公平正义与黑恶势力的较广州中医药大学大学城校区(广州中医药大学算名校吗)广州中医药大学大学城校区(广州中医药大学算名校吗)在985和211贫乏的广东省,双一流学校新贵是值得关注的,在此向大家介绍一所最近非常火爆的大学,广州中医药大学,作为高考志愿填报参非你莫属晕倒(法国留学生郭杰真相)非你莫属晕倒(法国留学生郭杰真相)几年前,张绍刚在天津卫视主持的求职招聘类节目非你莫属某期节目因一些言论推上风口浪尖。而就在非你莫属2012年5月20日的节目中视频,一个山西的应聘潘石屹非你莫属(非你莫属潘石屹全部)潘石屹非你莫属(非你莫属潘石屹全部)最早对潘石屹的印象是,一个中专毕业下海经商,敢冒风险借钱炒房,创建SOHO盆满钵满,善于经营一代儒商。我一度非常佩服他。看过他参加的好多期叫非你非你莫属微博(非你莫属最漂亮的美女)非你莫属微博(非你莫属最漂亮的美女)01hrBOSS团的毒让多少老板中招非你莫属开播于2010年,至今正好十年。尽管已经有十个年头,但丝毫没有减退这档节目的火爆程度。2017年,吉非你莫属黄欢(非你莫属田野黄欢)非你莫属黄欢(非你莫属田野黄欢)原创新10亿商业参考20201023164603文特约作者落日海盗编辑浅夏来源新10亿商业参考(IDxsyshangyecankao)2020年10非主流空间背景音乐(qq空间非主流英文歌曲)非主流空间背景音乐(qq空间非主流英文歌曲)原创杰出世界201903091435Hi,大家好,欢迎走进新一期的豆丁侃音乐,我是豆丁!最近腾讯宣布QQ用户可以自行选择注销自己的账号,合作社管理制度(农民专业合作社制度大全)合作社管理制度(农民专业合作社制度大全)XX县ZZ养殖专业合作社三会制度第一条为了保护合作社社员的合法权益,规范理事会监事会行为,依据中华人民共和国专业合作社法和本社章程规定,特制农村经济合作社(农村土地合作社每亩补多少钱)农村经济合作社(农村土地合作社每亩补多少钱)回顾农民专业合作社法实施的这12年,全国各地的农民专业合作社发展迅速,登记注册数量和加入合作社的成员数量激增,社会和市场对合作社的认知程
尖锐湿疣外用药(女性湿锐尤治疗的最好方法)尖锐湿疣外用药(女性湿锐尤治疗的最好方法)柴胡液外洗治疗尖锐湿疣刘维忠王世彪尖锐湿疣又称尖圭湿疣生殖器疣或性病疣,是由人类乳头瘤病毒(HPV)感染引起的一种性传播疾病,主要通过性接蚂蚁庄园今日问题古代的圣旨都是黄色的吗支付宝蚂蚁庄园小鸡问答8月26日相信现在大家对于小鸡庄园每日问答都是非常关心的吧,并且近期发现很多小伙伴都很想知道古代的圣旨都是黄色的吗支付宝蚂蚁庄园小鸡问答8月26日这个问题,那么既然现在小伙伴们对于古代的圣旨蚂蚁庄园今日问题画眉之风起于战国时期古代女子最早是用什么画眉的相信现在大家对于小鸡庄园每日问答都是非常关心的吧,并且近期发现很多小伙伴都很想知道画眉之风起于战国时期古代女子最早是用什么画眉的这个问题,那么既然现在小伙伴们对于画眉之风起于战国时支付宝蚂蚁庄园小鸡问答画眉之风起于战国时期古代女子最早是用什么画眉的相信现在大家对于小鸡庄园每日问答都是非常关心的吧,并且近期发现很多小伙伴都很想知道画眉之风起于战国时期古代女子最早是用什么画眉的这个问题,那么既然现在小伙伴们对于画眉之风起于战国时支付宝蚂蚁庄园小鸡问答古代女子最早是用什么画眉的蚂蚁庄园今日答案10月25日相信现在大家对于小鸡庄园每日问答都是非常关心的吧,并且近期发现很多小伙伴都很想知道古代女子最早是用什么画眉的蚂蚁庄园今日答案10月25日这个问题,那么既然现在小伙伴们对于古代女子最蚂蚁庄园今日问题自动扶梯的阶梯旁边会有一排毛刷这有什么用支付宝蚂蚁庄园小鸡问答7月29日支付宝的蚂蚁庄园小鸡问答是每天都会有不同的答题出现,一方面丰富我们的知识,另一方面也增加了养护小鸡的乐趣,就像今天支付宝蚂蚁庄园小鸡问答就出现了自动扶梯的阶梯旁边会有一排毛刷这有什蚂蚁庄园今日问题人们在冬季经常会冷得不自觉发抖这是因为支付宝蚂蚁庄园小鸡问答7月29日支付宝的蚂蚁庄园小鸡问答是每天都会有不同的答题出现,一方面丰富我们的知识,另一方面也增加了养护小鸡的乐趣,就像今天支付宝蚂蚁庄园小鸡问答就出现了人们在冬季经常会冷得不自觉发抖这是因蚂蚁庄园今日问题为什么遭到磕碰后皮肤上会出现乌青块支付宝的蚂蚁庄园小鸡问答是每天都会有不同的答题出现,一方面丰富我们的知识,另一方面也增加了养护小鸡的乐趣,就像今天支付宝蚂蚁庄园小鸡问答就出现了为什么遭到磕碰后皮肤上会出现乌青块,蚂蚁庄园今日问题为什么人在长大后会感觉眼睛变小了支付宝蚂蚁庄园小鸡问答7月27日支付宝的蚂蚁庄园小鸡问答是每天都会有不同的答题出现,一方面丰富我们的知识,另一方面也增加了养护小鸡的乐趣,就像今天支付宝蚂蚁庄园小鸡问答就出现了为什么人在长大后会感觉眼睛变小了支付支付宝蚂蚁庄园小鸡问答为什么遭到磕碰后皮肤上会出现乌青块相信现在大家对于小鸡庄园每日问答都是非常关心的吧,并且近期发现很多小伙伴都很想知道为什么遭到磕碰后皮肤上会出现乌青块这个问题,那么既然现在小伙伴们对于为什么遭到磕碰后皮肤上会出现乌支付宝蚂蚁庄园小鸡问答为什么遭到磕碰后皮肤上会出现乌青块蚂蚁庄园今日答案9月30日相信现在大家对于小鸡庄园每日问答都是非常关心的吧,并且近期发现很多小伙伴都很想知道为什么遭到磕碰后皮肤上会出现乌青块蚂蚁庄园今日答案9月30日这个问题,那么既然现在小伙伴们对于为什