sql 触发器(sql数据库触发器怎么写)
Sql触发器(如何编写sql数据库触发器)
触发器是SQL server提供给程序员和数据分析师的一种确保数据完整性的 *** 。它是一个与表事件相关的特殊存储过程。它的执行不是由程序调用或手动启动,而是由事件触发。当一个表 *** 作(插入、删除、更新)时,它将被激活执行。触发器通常用于加强数据完整性约束和业务规则。
一.触发器的优点1.触发是自动的。对表中的数据进行任何更改后,它会立即被激活。
2.可以通过数据库中的相关表级联修改触发器。
3.触发器可以施加限制。这些限制比检查约束定义的限制更复杂。与CHECK约束不同,触发器可以引用其他表中的列。
第二,触发器的分类SqlServer包括三种常规类型的触发器:DML触发器、DDL触发器和登录触发器。
1.DML(数据操作语言)触发器
DML触发器是附加到特定表或视图的一些操作码,当数据库服务器中发生数据操作语言事件时执行。SqlServer中有三种DML触发器:
插入触发器:向表中插入数据时触发;
删除触发器:从表中删除数据时触发;
更新触发器:当表中的数据被修改时触发。
当遇到以下情况时,应考虑DML触发器:
通过数据库中的相关表级联更改
防止恶意或错误的插入、更新和删除操作,并使用由检查约束定义的更复杂的限制来实施其他限制。
评估数据修改前后表的状态,并根据差异采取措施。
2.DDL(数据定义语言)触发器
当服务器或数据库中发生数据定义语言事件(主要是以create、drop、alter alter开头的语句)时,将激活并使用DDL触发器。使用DDL触发器可以防止对数据架构进行某些更改,或者记录数据中的更改或事件操作。
3.登录触发器
登录触发器将触发存储过程以响应登录事件。当与SQL Server实例建立用户会话时,将引发此事件。登录触发器将在登录的身份验证阶段完成之后、用户会话实际建立之前被触发。因此,触发器内部通常会到达用户的所有消息(如错误消息和来自PRINT语句的消息)都将被发送到SQL Server错误日志。如果身份验证失败,将不会触发登录触发器。
三、触发器的工作原理【删除、插入、更新】对应的是执行删除、插入、更新三个动作时被触发。
插入时,获取插入的数据,可以通过select*from inserted读取。
执行删除时,获取删除前的数据,可以通过select*from deleted读取。
更新时,获取更新前的数据,可以用select *从删除中读取,获取更新数据,用select *从插入中读取。
第四,创建触发器1.创建触发器的语法:
CREATETRIGGERtrigger_nameONtable_name[WITHENCRYPTION]FOR|AFTER|INSTEADOF[DELETE,INSERT,UPDATE]AST-SQL语句GO--withencryption表示加密触发器定义的sql文本--delete,insert,update指定触发器的类型2.创建插入触发器
--创建insert触发器createtriggertrig_insertonstudentafterinserta *** eginifobject_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触发器createtriggertrig_deleteonstudentafterdeletea *** eginselectstu_idas已删除的学生编号,stu_namestu_gender,stu_agefromdeletedend;--执行一一条delete语句触发trig_delete触发器deletefromstudentwherestu_id=1;4.创建更新触发器
当用户对指定的表执行Update语句时,将调用update触发器。这种类型的触发器用于限制用户对数据的修改。更新触发器可以执行两个操作:更新前的记录存储在删除的表中,更新后的记录存储在插入的表中。
--创建update触发器createtriggertrig_updateonstudentafterupdatea *** egindeclare@stuCountint;select@stuCount=count(*)fromstudent;updatestudent_sumsetstuCount=@stuCount;selectstu_idas更新前学生编号,stu_nameas更新前学生姓名fromdeletedselectstu_idas更新后学生编号,stu_nameas更新后学生姓名frominsertedend--创建完成,执行一条update语句触发trig_update触发器updatestudentsetstu_name='张飞'wherestu_id=2;动词 (verb的缩写)管理触发器1.检查扳机
(1).检查数据库中的所有触发器。
--查看数据库中所有的触发器use数据库名goselect*fromsysobjectswherextype='TR'Sysobjects保存数据库的对象,其中xtype TR的记录是触发器对象。在name列中,我们可以看到触发器名称。
(2).sp_helptext以查看触发器内容
use数据库名goexecsp_helptext'触发器名称'触发内容将以表格形式显示。
除了触发器之外,sp_helptext还可以显示规则、默认值、未加密的存储过程、用户定义的函数和视图的文本。
(3).sp_helptrigger用于查看触发器的属性。
Sp_helptrigger有两个参数:之一个参数是表名;第二个触发器类型是char(6),可以插入、更新或删除。如果省略,将显示指定表中所有类型触发器的属性。
- 1bat的大数据(BAT的大数据来源)
- 2三星s8屏幕上端2(三星s8屏幕上端2个按键)
- 3三星屏幕坏了如何导出(三星屏幕摔坏了如何导出数据么)
- 4红米3x怎么关闭自动更新(红米k40s怎么关闭自动更新)
- 5微信上防止app自动下载软件怎么办(微信上防止app自动下载软件怎么办啊)
- 6押镖多少钱(押镖一个月有多少储备金)
- 7瑞星个人防火墙胡功能(瑞星个人防火墙协议类型有哪些)
- 8cf现在等级是多少(cf等级2020最新)
- 9老滑头多少条鱼(钓鱼老滑头有什么用)
- 10WPS自动调整语法(wps如何修改语法)
- 11dell控制面板防火墙(dell的防火墙怎么关闭)
- 12丑女技能升多少(丑女技能需要满级吗)
- 13智能家居系统怎么样(智能家居系统好吗)
- 14戴尔屏幕(戴尔屏幕闪烁)
- 15y85屏幕信息(vivoy85息屏显示时间怎么设置)
- 16魅蓝note3屏幕出现方格(魅蓝note屏幕竖条纹)
- 17v8手指按屏幕(触屏手指)
- 18金为液晶广告机(液晶广告机lb420)
- 19三星显示器怎么校色(三星显示器 调色)
- 20hkc显示器dvi音频(hkc显示器有音响么)
- 21康佳液晶智能电视机(康佳液晶智能电视机怎么样)
- 22做液晶画板电脑(做液晶画板电脑怎么操作)
- 23液晶屏极化现象原理(液晶屏极化现象原理是什么)
- 24企业网络安全防火墙(企业网络防护)
- 256splus黑屏屏幕不亮(苹果6s plus屏幕突然黑屏)
- 26充电导致屏幕失灵(充电导致屏幕失灵怎么办)
- 27超极本屏幕旋转(笔记本电脑屏幕旋转,怎么转过来?)
- 28igmp防火墙(防火墙配置ipv6)
- 29荣耀王者多少经验(王者荣耀经验多少一级)
- 30lol老将还剩多少(qg老将)