加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

数据库中存储过程和触发器有什么区别

发布时间:2019-04-30 23:44:41 所属栏目:MySql教程 来源:IT生涯
导读:存储过程和触发器都是数据库中非常重要的知识,接下来将在文章中通过许多方面来比较这两者之间的不同,具有一定的参考作用希望对大家有所帮助。 什么是触发器? 触发器是数据库中的表/视图发生某些特定事件时自动执行的过程(代码段)。触发器主要用于维护

数据库中存储过程和触发器有什么区别

存储过程和触发器都是数据库中非常重要的知识,接下来将在文章中通过许多方面来比较这两者之间的不同,具有一定的参考作用希望对大家有所帮助。

什么是触发器?

触发器是数据库中的表/视图发生某些特定事件时自动执行的过程(代码段)。触发器主要用于维护数据库中的完整性。触发器还用于实施业务规则,审核数据库中的更改以及复制数据。最常见的触发器是在操作数据时触发数据操作语言(DML)触发器。某些数据库系统支持非数据触发器,这些触发器在发生数据定义语言(DDL)事件时触发。这些触发器可以特别用于审计。Oracle数据库系统支持模式级触发器

什么是存储过程?

存储过程是可以由访问关系数据库的应用程序。通常,存储过程用作验证数据和控制对数据库的访问。如果某些数据处理操作需要执行多个SQL语句,则此类操作将作为存储过程实现。调用存储过程时,必须使用CALL或EXECUTE语句。存储过程可以返回结果(例如SELECT语句的结果)。这些结果可以由其他存储过程或应用程序使用。用于编写存储过程的语言通常支持控制结构,例如if,while,for等。根据所使用的数据库系统,可以使用多种语言来实现存储过程

存储过程和触发器的区别

(1)存储过程是一组已创建并存储在数据库中的SQL语句。所以我们可以一遍又一遍地重用代码。而触发器是一种特殊的不是由用户直接调用存储过程,创建触发器时,会定义在针对特定表或列进行特定类型的数据修改时触发。

(2)用户可以使用Execute或Exec语句来直接调用或执行存储过程,而无法直接调用或执行触发器。触发相关事件时,只会自动执行触发器。

(3)存储过程可以采用输入参数,而触发器中不能将参数作为输入我们不能将参数作为输入传递给触发器。

(4)存储过程可以返回零或n值,触发器无法返回值。

(5)我们可以在存储过程中使用事务,触发器内不允许进行事务处理

(6)存储过程通常用于执行用户指定的任务,触发器通常用于审计工作

【编辑推荐】

  1. 数据库运维技能篇:MySQL常用必备命令详解
  2. 3分钟了解十种侵入数据库方法,防患未然早做准备
  3. 如何用正确的态度审视SQL Server数据库
  4. 开发分布式SQL数据库的6种技术挑战
  5. 实时数据库:一夜之间,我感受到了时序数据库的威胁
【责任编辑:庞桂玉 TEL:(010)68476606】
点赞 0

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读