SQL Server存储过程和触发器的区别
存储过程
存储过程是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
存储过程是可以访问关系数据库的应用程序。
通常,存储过程用作验证数据和控制对数据库的访问。如果某些数据处理操作需要执行多个SQL语句,则此类操作将作为存储过程实现。调用存储过程时,必须使用CALL或EXECUTE语句。
存储过程可以返回结果(例如SELECT语句的结果)。这些结果可以由其他存储过程或应用程序使用。用于编写存储过程的语言通常支持控制结构,例如if,while,for等。
根据所使用的数据库系统,可以使用多种语言来实现存储过程。
优点:
1允许模块化程序设计(创建一次多次使用)
2允许更快执行
3减少网络流量
4更好的安全机制
格式:
DELIMITER //
CREATE PROCEDURE 储存名([ IN ,OUT ,INOUT ]?参数名?数据类形…)
BEGIN
SQL语句
END //
DELIMITER ;
调用过程:
用call 过程名( )
查看所有的存储过程show procedure status;
查看创建的存储过程show create procedure 过程名;
删除过程 drop procedure 过程名
In 表示参数从外部传入到里面使用(过程内部使用)
Out 表示参数从过程里边把数据保存到变量中,交给外部使用,所有传入的必须是变量 如果说传入的out变量本身在外部有数据,那么在进入过程之后,第一件事就是被清空,设为null
Inout 数据可以从外部传入到过程内部使用,同时内部操作之后,又会将数据返回给外部
触发器
触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行。它又不同于存储过程,触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而被直接调用。
触发器是数据库中的表/视图发生某些特定事件时自动执行的过程(代码段)。触发器主要用于维护数据库中的完整性。触发器还用于实施业务规则,审核数据库中的更改以及复制数据。最常见的触发器是在操作数据时触发数据操作语言(DML)触发器。某些数据库系统支持非数据触发器,这些触发器在发生数据定义语言(DDL)事件时触发。这些触发器可以特别用于审计。Oracle数据库系统支持模式级触发器。
作用:
1.可在写入数据表前,强制检验或转换数据
2.触发器发生错误时,异动的结果会被撤销
格式
DELIMITER //
Create trigger 触发器名字 触发时机 触发事件 on 表 for each
row
Begin
操作的内容
End //
DELIMITER ;
触发对象 :on 表 for each row 触发器绑定实质是表中的所有行,因此当每一行发生改变的时候,就会触发触发器 。
触发时机:每张表中对应的行都会有不同的状态,当SQL 指令发生的时候,都会令行中的数据发生改变,每一行总会有两个状态。操作数据之前(before),操作数据(after)之后
触发事件:
Mysql中触发器针对的目标是数据发生改变,对应的操作只有(增,删,改)查询不发生数据的改变,
所以查询没有触发事件
注意事项:
一张表中,每一个触发器时机绑定的触发事件对应的触发器类型只能有一个;
一张表中只能有一个after insert 触发器 因此,一张表中最多的触发器只能有六个。
存储过程和触发器的区别
(1)存储过程是一组已创建并存储在数据库中的SQL语句。所以我们可以一遍又一遍地重用代码。而触发器是一种特殊的不是由用户直接调用存储过程,创建触发器时,会定义在针对特定表或列进行特定类型的数据修改时触发。
(2)用户可以使用Execute或Exec语句来直接调用或执行存储过程,而无法直接调用或执行触发器。触发相关事件时,只会自动执行触发器。
(3)存储过程可以采用输入参数,而触发器中不能将参数作为输入我们不能将参数作为输入传递给触发器。
(4)存储过程可以返回零或n值,触发器无法返回值。
(5)我们可以在存储过程中使用事务,触发器内不允许进行事务处理
(6)存储过程通常用于执行用户指定的任务,触发器通常用于审计工作
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现