`

触发器、存储过程和函数三者有和区别

阅读更多

触发器是特殊的存储过程存储过程需要程序调用,而触发器会自动执行;

你所说的函数是自定义函数吧,函数是根据输入产生输出,自定义只不过输入输出的关系由用户来定义。

 

》在什么时候用触发器?

 要求系统根据某些操作自动完成相关任务。

 比如:

        根据买掉的产品的输入数量自动扣除该产品的库存量。

什么时候用存储过程?

 存储过程就是程序,它是经过语法检查和编译的SQL语句,所以运行特别快。

 

存储过程用户自定义函数具体的区别 :

⊙存储过程

存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。

存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。

可以出于任何使用 SQL 语句的目的来使用存储过程,它具有以下优点:

可以在单个存储过程中执行一系列 SQL 语句。
可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。
存储过程在创建时即在服务器上进行编译,所以执行起来比单个 SQL 语句快。
用户定义函数

 

⊙用户定义函数

函数是由一个或多个 Transact-SQL 语句组成的子程序,可用于封装代码以便重新使用。Microsoft? SQL Server? 2000 并不将用户限制在定义为 Transact-SQL 语言一部分的内置函数上,而是允许用户创建自己的用户定义函数。

可使用 CREATE FUNCTION 语句创建、使用 ALTER FUNCTION 语句修改、以及使用 DROP FUNCTION 语句除去用户定义函数。每个完全合法的用户定义函数名 (database_name.owner_name.function_name) 必须唯一。


必须被授予 CREATE FUNCTION 权限才能创建、修改或除去用户定义函数。不是所有者的用户在 Transact-SQL 语句 

中使用某个函数之前,必须先给此用户授予该函数的适当权限。若要创建或更改在 CHECK 约束、DEFAULT 子句或计算

列定义中引用用户定义函数的表,还必须具有函数的 REFERENCES 权限。

在函数中,区别处理导致删除语句并且继续在诸如触发器或存储过程等模式中的下一语句的 Transact-SQL 错误。在函数中,上述错误会导致停止执行函数。接下来该操作导致停止唤醒调用该函数的语句。

 

分享到:
评论

相关推荐

    触发器、存储过程和函数三者有何区别四.pdf

    【触发器、存储过程和函数的区别】 触发器、存储过程和函数都是数据库管理系统中的重要组件,它们各自在特定场景下发挥着不同的作用。 1. **触发器(Triggers)** - 触发器是一种特殊的存储过程,它会在特定的...

    自定义函数、存储过程和触发器.pdf

    ### 自定义函数、存储过程和触发器 #### 9.1 自定义函数 自定义函数是在SQL Server中由用户自行创建的一种子程序,用于补充和扩展系统提供的内置函数功能。自定义函数的主要目的是提高代码的复用性以及解决特定...

    解密SQL触发器、存储过程、函数

    SQL触发器、存储过程和函数是数据库管理中的重要组成部分,它们极大地增强了数据库的功能性和灵活性。在本篇文章中,我们将深入探讨这些概念,并提供实用的示例来帮助理解它们的使用和重要性。 **SQL触发器...

    oracle存储过程、函数和触发器

    在"存储过程、函数和触发器-授课源代码"这个压缩包中,可能包含了示例代码,帮助学习者理解和实践这些概念。这些源代码通常会涵盖如何创建、调用和管理这些数据库对象的实例。通过分析和运行这些代码,你可以更深入...

    存储过程、触发器和函数实验.pdf

    在IT领域,数据库管理和编程是核心技能之一,存储过程、触发器和函数是数据库系统中的重要组成部分,它们有助于提升数据库的效率和安全性。本实验主要围绕这三个概念进行,旨在加深对它们的理解和应用。 首先,存储...

    Oracle数据库--存储过程、函数、触发器和包.pptx

    存储过程可以有参数,参数分为三种类型:`IN`、`OUT`和`IN OUT`。`IN`参数只用于接收调用者的值,`OUT`参数则用于将过程内部计算的结果返回给调用者,而`IN OUT`参数两者兼备。 【带参数的存储过程】 创建带参数的...

    MYSQL的存储过程和函数简单写法

    与触发器相似,存储过程也是一组SQL语句的集合,但关键区别在于触发器是自动触发的,而存储过程是主动调用的。存储过程的优点包括: 1. **模块化**:存储过程将复杂操作封装起来,提高了代码的可读性和可维护性。 2...

    存储过程、触发器、定时器例子(oracle)

    在Oracle数据库系统中,存储过程、触发器和定时器是三个关键的数据库管理工具,它们在数据处理和业务逻辑执行中扮演着重要角色。本文将详细介绍这三个概念,并结合实际例子来帮助理解它们的工作原理和应用。 1. **...

    计算机Ch存储过程和触发器PPT课件.pptx

    默认情况下,只有数据库所有者有创建存储过程的权限,但可以将其授予其他用户。存储过程的大小上限为128MB,且可以在SQL Server启动时自动执行,但需由系统管理员在master数据库中创建并设定。 **触发器**: 触发器...

    oracle 视图,函数,过程,触发器自动编译脚本

    3. **查询失效对象**:脚本通过`sqlplus`工具连接到Oracle数据库,并执行一段SQL脚本来查找所有类型为触发器(Trigger)、过程(Procedure)、函数(Function)和视图(View),且状态为无效的对象。为了排除系统...

    过程 -触发器 -包

    过程和函数用于执行计算或业务逻辑,触发器则提供了在特定操作前后自动执行代码的能力,而包则把这些组件整理成一个易于管理和使用的整体。在Oracle环境中,这种结构化的编程方式对于开发高效、可靠的数据库解决方案...

    sql防注入触发器

    为了防止这种攻击,开发人员需要采取一系列措施,包括参数化查询、存储过程以及使用触发器等技术。 #### 二、触发器概述 在SQL Server中,触发器是一种特殊类型的存储过程,它被定义为当特定事件(如INSERT、UPDATE...

    sqlsever存储过程

    十一、存储过程与触发器、函数的区别 存储过程是可执行的代码块,可以包含控制流语句;而触发器是在特定数据库事件(如INSERT, UPDATE, DELETE)发生时自动执行;函数则返回一个值,通常用于计算或验证。 总结,SQL...

    触发器实验C#

    触发器是一种特殊的存储过程,它被定义为响应特定类型的事件(如数据的插入、更新或删除)而自动执行。触发器通常用于确保数据完整性,执行业务规则或者记录审计日志等。 #### 二、C#与数据库触发器的关系 虽然C#...

    数据库编程-存储过程-触发器-级联更新-SQL-server-游标、全网最全最详细编程实战

    - 学会如何在存储过程中使用变量、条件判断和循环结构。 #### 三、操作要点 1. **掌握T-SQL基本语法**: - 学习并熟练掌握SQL Server中T-SQL的基本语法规则。 - 包括但不限于:数据定义语言(DDL)、数据操纵语言...

    oracle 的包,层次化查询和触发器视频教程

    本教程主要涵盖Oracle数据库中的“包”、“层次化查询”和“触发器”这三个关键概念,对于初学者来说,理解并掌握这些知识对于进一步深入学习Oracle数据库至关重要。 首先,让我们详细探讨“包”(Package)。在...

    SqlServerCH创建和管理存储过程PPT课件.pptx

    创建、执行、修改和删除自定义函数的流程与存储过程类似,只是在用途和返回值上有区别。 总的来说,学习这部分内容有助于理解如何在SQL Server中更高效、安全地管理和操作数据,以及如何利用存储过程和自定义函数...

    mysql中文手册+mysql命令大全+mysql存储过程

    CHM文件是一种Windows帮助文件,包含了大量的MySQL知识,如数据库概念、安装配置、SQL语法、索引、视图、触发器、存储过程和函数等。这个手册可以帮助用户快速查找并理解MySQL的各种功能和操作,尤其对于初学者来说...

Global site tag (gtag.js) - Google Analytics