sql中的触发器与存储过程有什么相同点和不同点?希望能专业点,谢谢
2022-09-28 · 百度认证:北京惠企网络技术有限公司官方账号
一、功能不同:
1、存储过程的功能:
(1) 变量说明
(2) ANSI(美国国家标准化组织)兼容的SQL命令(如Select,Update….)
(3) 一般流程控制命令(if…else…、while….)
2、触发器的功能:
(1)强化约束(Enforce
restriction)
(2)跟踪变化Auditing
changes
(3)级联运行(Cascaded
operation)
二、指代不同
存储过程:在大型数据库系统中,一组为了完成特定功能的SQL语句集。
触发器:SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法。
三、作用不同:
1、存储过程:局时存储过程,以两个井字号(##)号开始,则该存储过程将成为一个存储在tempdb数据库中的全局临时存储过程,全局临时存储过程一旦创建,以后连接到服务器的任意用户都可以执行它,而且不需要特定的权限。
2、触发器:可用于强制引用完整性,以便在多个表中添加、更新或删除行时,保留在这些表之间所定义的关系。然而,强制引用完整性的最好方法是在相关表中定义主键和外键约束。
四、相同点:
触发器是自动的:它们在对表的数据作了任何修改(比如手工输入或者应用程序采取的操作)之后立即被激活。
触发器可以通过数据库中的相关表进行层叠更改。例如,可以在 titles 表的 title_id 列上写入一个删除触发器,以使其它表中的各匹配行采取删除操作。该触发器用 title_id 列作为唯一键,在 titleauthor、sales 及 roysched 表中对各匹配行进行定位。
触发器可以强制限制,这些限制比用 CHECK 约束所定义的更复杂。与 CHECK 约束不同的是,触发器可以引用其它表中的列。
扩展资料:
触发器可通过数据库中的相关表实现级联更改;通过级联引用完整性约束可以更有效地执行这些更改。触发器可以强制用比 CHECK 约束定义的约束更为复杂的约束。与CHECK约束不同,触发器可以引用其它表中的列。例如,触发器可以使用另一个表中的 SELECT 比较插入或更新的数据,以及执行其它操作,如修改数据或显示用户定义错误信息。
触发器也可以评估数据修改前后的表状态,并根据其差异采取对策。
参考资料来源:百度百科-SQL触发器