触发器、存储过程和函数三者有何区别?
回复:触发器、存储过程和函数三者有何区别?
触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行;你所说的函数是自定义函数吧,函数是根据输入产生输出,自定义只不过输入输出的关系由用户来定义。在什么时候用触发器?要求系统根据某些操作自动完成相关任务,比如,根据买掉的产品的输入数量自动扣除该产品的库存量。什么时候用存储过程?存储过程就是程序,它是经过语法检查和编译的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 错误。在函数中,上述错误会导致停止执行函数。接下来该操作导致停止唤醒调用该函数的语句。
用户定义函数的类型
SQL Server 2000 支持三种用户定义函数:
用户定义函数采用零个或更多的输入参数并返回标量值或表。函数最多可以有 1024 个输入参数。当函数的参数有默认值时,调用该函数时必须指定默认 DEFAULT 关键字才能获取默认值。该行为不同于在存储过程中含有默认值的参数,而在这些存储过程中省略该函数也意味着省略默认值。用户定义函数不支持输出参数。
标量函数返回在 RETURNS 子句中定义的类型的单个数据值。可以使用所有标量数据类型,包括 bigint 和 sql_variant。不支持 timestamp 数据类型、用户定义数据类型和非标量类型(如 table 或 cursor)。在 BEGIN...END 块中定义的函数主体包含返回该值的 Transact-SQL 语句系列。返回类型可以是除 text、ntext、image、cursor 和 timestamp 之外的任何数据类型。
表值函数返回 table。对于内嵌表值函数,没有函数主体;表是单个 SELECT 语句的结果集。对于多语句表值函数,在 BEGIN...END 块中定义的函数主体包含 TRANSACT-SQL 语句,这些语句可生成行并将行插入将返回的表中。有关内嵌表值函数的更多信息,请参见内嵌用户定义函数。有关表值函数的更多信息,请参见返回 table 数据类型的用户定义函数。
BEGIN...END 块中的语句不能有任何副作用。函数副作用是指对具有函数外作用域(例如数据库表的修改)的资源状态的任何永久性更改。函数中的语句唯一能做的更改是对函数上的局部对象(如局部游标或局部变量)的更改。不能在函数中执行的操作包括:对数据库表的修改,对不在函数上的局部游标进行操作,发送电子邮件,尝试修改目录,以及生成返回至用户的结果集。
函数中的有效语句类型包括:
- DECLARE 语句,该语句可用于定义函数局部的数据变量和游标。
- 为函数局部对象赋值,如使用 SET 给标量和表局部变量赋值。
- 游标操作,该操作引用在函数中声明、打开、关闭和释放的局部游标。不允许使用 FETCH 语句将数据返回到客户端。仅允许使用 FETCH 语句通过 INTO 子句给局部变量赋值。
- 控制流语句。
- SELECT 语句,该语句包含带有表达式的选择列表,其中的表达式将值赋予函数的局部变量。
- INSERT、UPDATE 和 DELETE 语句,这些语句修改函数的局部 table 变量。
- EXECUTE 语句,该语句调用扩展存储过程。
在查询中指定的函数的实际执行次数在优化器生成的执行计划间可能不同。示例为 WHERE 子句中的子查询唤醒调用的函数。子查询及其函数执行的次数会因优化器选择的访问路径而异。
用户定义函数中不允许使用会对每个调用返回不同数据的内置函数。用户定义函数中不允许使用以下内置函数:
@@CONNECTIONS |
@@PACK_SENT |
GETDATE |
@@CPU_BUSY |
@@PACKET_ERRORS |
GetUTCDate |
@@IDLE |
@@TIMETICKS |
NEWID |
@@IO_BUSY |
@@TOTAL_ERRORS |
RAND |
@@MAX_CONNECTIONS |
@@TOTAL_READ |
TEXTPTR |
@@PACK_RECEIVED |
@@TOTAL_WRITE |
|
架构绑定函数
CREATE FUNCTION 支持 SCHEMABINDING 子句,后者可将函数绑定到它引用的任何对象(如表、视图和其它用户定义函数)的架构。尝试对架构绑定函数所引用的任何对象执行 ALTER 或 DROP 都将失败。
必须满足以下条件才能在 CREATE FUNCTION 中指定 SCHEMABINDING:
- 该函数所引用的所有视图和用户定义函数必须是绑定到架构的。
- 该函数所引用的所有对象必须与函数位于同一数据库中。必须使用由一部分或两部分构成的名称来引用对象。
- 必须具有对该函数中引用的所有对象(表、视图和用户定义函数)的 REFERENCES 权限。
可使用 ALTER FUNCTION 删除架构绑定。ALTER FUNCTION 语句将通过不带 WITH SCHEMABINDING 指定函数来重新定义函数。
调用用户定义函数
当调用标量用户定义函数时,必须提供至少由两部分组成的名称:
SELECT *, MyUser.MyScalarFunction()
FROM MyTable
可以使用一个部分构成的名称调用表值函数:
SELECT *
FROM MyTableFunction()
然而,当调用返回表的 SQL Server 内置函数时,必须将前缀 :: 添加至函数名:
SELECT * FROM ::fn_helpcollations()
可在 Transact-SQL 语句中所允许的函数返回的相同数据类型表达式所在的任何位置引用标量函数,包括计算列和 CHECK 约束定义。例如,下面的语句创建一个返回 decimal 的简单函数:
CREATE FUNCTION CubicVolume
-- Input dimensions in centimeters
(@CubeLength decimal(4,1), @CubeWidth decimal(4,1),
@CubeHeight decimal(4,1) )
RETURNS decimal(12,3) -- Cubic Centimeters.
AS
BEGIN
RETURN ( @CubeLength * @CubeWidth * @CubeHeight )
END
然后可以在允许整型表达式的任何地方(如表的计算列中)使用该函数:
CREATE TABLE Bricks
(
BrickPartNmbr int PRIMARY KEY,
BrickColor nchar(20),
BrickHeight decimal(4,1),
BrickLength decimal(4,1),
BrickWidth decimal(4,1),
BrickVolume AS
(
dbo.CubicVolume(BrickHeight,
BrickLength, BrickWidth)
)
)
dbo.CubicVolume 是返回标量值的用户定义函数的一个示例。RETURNS 子句定义由该函数返回的值的标量数据类型。BEGIN...END 块包含一个或多个执行该函数的 Transact-SQL 语句。该函数中的每个 RETURN 语句都必须具有一个参数,可返回具有在 RETURNS 子句中指定的数据类型(或可隐性转换为 RETURNS 中指定类型的数据类型)的数据值。RETURN 参数的值是该函数返回的值。
分享到:
相关推荐
【触发器、存储过程和函数的区别】 触发器、存储过程和函数都是数据库管理系统中的重要组件,它们各自在特定场景下发挥着不同的作用。 1. **触发器(Triggers)** - 触发器是一种特殊的存储过程,它会在特定的...
### 自定义函数、存储过程和触发器 #### 9.1 自定义函数 自定义函数是在SQL Server中由用户自行创建的一种子程序,用于补充和扩展系统提供的内置函数功能。自定义函数的主要目的是提高代码的复用性以及解决特定...
SQL触发器、存储过程和函数是数据库管理中的重要组成部分,它们极大地增强了数据库的功能性和灵活性。在本篇文章中,我们将深入探讨这些概念,并提供实用的示例来帮助理解它们的使用和重要性。 **SQL触发器...
在"存储过程、函数和触发器-授课源代码"这个压缩包中,可能包含了示例代码,帮助学习者理解和实践这些概念。这些源代码通常会涵盖如何创建、调用和管理这些数据库对象的实例。通过分析和运行这些代码,你可以更深入...
在IT领域,数据库管理和编程是核心技能之一,存储过程、触发器和函数是数据库系统中的重要组成部分,它们有助于提升数据库的效率和安全性。本实验主要围绕这三个概念进行,旨在加深对它们的理解和应用。 首先,存储...
存储过程可以有参数,参数分为三种类型:`IN`、`OUT`和`IN OUT`。`IN`参数只用于接收调用者的值,`OUT`参数则用于将过程内部计算的结果返回给调用者,而`IN OUT`参数两者兼备。 【带参数的存储过程】 创建带参数的...
与触发器相似,存储过程也是一组SQL语句的集合,但关键区别在于触发器是自动触发的,而存储过程是主动调用的。存储过程的优点包括: 1. **模块化**:存储过程将复杂操作封装起来,提高了代码的可读性和可维护性。 2...
在Oracle数据库系统中,存储过程、触发器和定时器是三个关键的数据库管理工具,它们在数据处理和业务逻辑执行中扮演着重要角色。本文将详细介绍这三个概念,并结合实际例子来帮助理解它们的工作原理和应用。 1. **...
默认情况下,只有数据库所有者有创建存储过程的权限,但可以将其授予其他用户。存储过程的大小上限为128MB,且可以在SQL Server启动时自动执行,但需由系统管理员在master数据库中创建并设定。 **触发器**: 触发器...
### Oracle视图、函数、过程、触发器自动编译脚本知识点详解 #### 一、背景与需求 在日常管理维护Oracle数据库服务器的过程中,我们经常会遇到需要修改视图(View)、表(Table)结构的情况。由于Oracle中的视图、...
过程和函数用于执行计算或业务逻辑,触发器则提供了在特定操作前后自动执行代码的能力,而包则把这些组件整理成一个易于管理和使用的整体。在Oracle环境中,这种结构化的编程方式对于开发高效、可靠的数据库解决方案...
为了防止这种攻击,开发人员需要采取一系列措施,包括参数化查询、存储过程以及使用触发器等技术。 #### 二、触发器概述 在SQL Server中,触发器是一种特殊类型的存储过程,它被定义为当特定事件(如INSERT、UPDATE...
触发器是一种特殊的存储过程,它被定义为响应特定类型的事件(如数据的插入、更新或删除)而自动执行。触发器通常用于确保数据完整性,执行业务规则或者记录审计日志等。 #### 二、C#与数据库触发器的关系 虽然C#...
### 数据库编程实战知识点解析 #### 一、实验目的及要求 本次实验旨在通过实际操作加深学生...以上实验内容覆盖了数据库编程的基础知识和技术要点,通过实践操作,能够帮助学习者深入理解和掌握这些概念和技术的应用。
十一、存储过程与触发器、函数的区别 存储过程是可执行的代码块,可以包含控制流语句;而触发器是在特定数据库事件(如INSERT, UPDATE, DELETE)发生时自动执行;函数则返回一个值,通常用于计算或验证。 总结,SQL...
本教程主要涵盖Oracle数据库中的“包”、“层次化查询”和“触发器”这三个关键概念,对于初学者来说,理解并掌握这些知识对于进一步深入学习Oracle数据库至关重要。 首先,让我们详细探讨“包”(Package)。在...
创建、执行、修改和删除自定义函数的流程与存储过程类似,只是在用途和返回值上有区别。 总的来说,学习这部分内容有助于理解如何在SQL Server中更高效、安全地管理和操作数据,以及如何利用存储过程和自定义函数...
CHM文件是一种Windows帮助文件,包含了大量的MySQL知识,如数据库概念、安装配置、SQL语法、索引、视图、触发器、存储过程和函数等。这个手册可以帮助用户快速查找并理解MySQL的各种功能和操作,尤其对于初学者来说...