`

存储过程与函数的区别

 
阅读更多

1 存储过程

定义:

存储过程(Stored Procedure)是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。

优点:

A 存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次所以使用存储过程可提高数据库执行速度。

B 当对数据库进行复杂操作时(如对多个表进行UpdateInsertQueryDelete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。存储过程可以从自己的存储过程内调用其它存储过程,这可以简化一系列复杂语句

C 安全性高可设定只有某用户才具有对指定存储过程的使用权。

D 存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值,可以向程序返回错误原因。

 

2 合理使用存储过程与函数

存储过程参数可以有三种模式(INOUTIN OUT)可返回多个参数值可在过程中调用另一个存储过程

函数函数只有一种(IN)因为使用函数的目的是传入0或多个参数,它只有一条RETURN语句,只能返回单一的值也可用Out来返回值可在SQL语句(DMLSELECT)中调用

 

Oracle中的函数与存储过程的区别

A函数必须有返回值而过程没有

B函数可以单独执行而过程必须通过execute执行

C函数可以嵌入到SQL语句中执行而过程不行

其实我们可以将比较复杂的查询写成函数然后到存储过程中去调用这些函数

 

Oracle中的函数与存储过程的特点

A.一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。

B.对于存储过程来说可以返回参数,而函数只能返回值或者表对象。

C.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。

区别:

名称

是否有返回值

是否可以单独执行

是否可以嵌入SQL语句中

参数类型

返回值类型

存储过程

可以没有

必须通过execute执行

不可以

INOUTIN OUT

可以返回参数(一个或多个参数值)结果集、返回错误原因

自定义函数

有且只有一个

可以

可以可以位于FROM关键字的后面

只有IN

单一值或者一个表对象

                                                                                                                                    

触发器,存储过程和函数区别

触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行;函数是根据输入产生输出,自定义只不过输入输出的关系由用户来定义。在什么时候用触发器?要求系统根据某些操作自动完成相关任务,比如:根据买掉的产品的输入数量自动扣除该产品的库存量。什么时候用存储过程?存储过程就是程序,它是经过语法检查和编译的SQL语句,所以运行特别快。

分享到:
评论

相关推荐

    MySQL实验报告5(存储过程与函数)(1)(1).pdf

    函数与存储过程类似,也是一种子程序。不同之处在于函数必须返回一个值。报告中并没有直接提及函数的创建,但是存储过程中的某些操作可以通过函数来实现,比如获取表中的记录数等。 3. 使用游标 游标允许逐行遍历...

    存储过程和函数的区别

    ### 存储过程和函数的区别 #### 一、概述 在数据库编程中,存储过程(Stored Procedure)与函数(Function)都是预编译并存储在数据库服务器上的代码块,能够提高应用程序性能,简化复杂的数据库操作,并增强数据...

    第11章MySQL存储过程与函数.docx

    MySQL 存储过程与函数 MySQL 存储过程和函数是数据库中定义的一组用户定义的 SQL 语句集合。它们之间的区别在于: 1. 存储过程实现的功能要复杂一点,而函数实现的功能针对性比较强。 2. 存储过程可以返回参数,而...

    实验4存储过程和函数实验

    适合sqlserver数据库初学者,实验四存储过程和函数实验

    常用SQL工具存储过程与函数.rar

    本压缩包“常用SQL工具存储过程与函数.rar”可能包含了一些常见SQL工具中用于管理和操作数据库存储过程与函数的相关资料,如日志文件(spTool_Log.LDF)和数据文件(spTool_Data.MDF)。 存储过程是预编译的SQL语句...

    java调用oracle存储过程或者函数

    调用Oracle函数的过程与调用存储过程类似,但创建CallableStatement时的SQL语句略有不同。由于函数会返回一个值,所以格式通常是`{? = call function_name(?, ?, ...)}`。在执行后,通过`CallableStatement....

    VB 过程与函数的区别

    理解VB中的过程与函数的区别有助于编写更清晰、可维护的代码。在适当的时候使用Sub过程和Function函数,可以使程序逻辑更加明确,提高代码的可读性和效率。在设计VB程序时,应根据需要返回值的情况以及是否需要修改...

    Mysql存储过程和函数

    #### 二、存储过程与函数的区别 - **存储过程**(Stored Procedure):是一系列SQL语句的集合,它可以接受输入参数并返回多个结果集和返回值。存储过程可以提高代码复用性,减少网络流量,并且可以包含复杂的逻辑...

    原创sql存储过程函数范例

    原创sql存储过程函数范例,一是为了自己方便查找,今天到公司因为没有我保存的一些范例,一个简单的例子写了半个小时,如果有范例直接套几分钟肯定搞定,所以索性上传到CSDN上,何时何地都能找到我的范例了。...

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

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

    Oracle存储过程、函数和包

    - **命名存储**:与普通的PL/SQL块不同,存储过程和函数具有名称,并且这些名称在数据库中是唯一的。 - **安全性**:存储过程和函数的安全性由数据库管理,只有被授权的用户才能访问它们。 - **复用性**:存储过程和...

    存储过程和函数

    根据提供的文件信息,本文将详细解析数据库中的存储过程与函数,并深入探讨自主事务(autonomous_transaction)的概念及其在PL/SQL中的应用。 ### 一、存储过程 #### 1. 创建存储过程 存储过程是一种存储在数据库...

    oracle实验8-存储过程与函数的创建.doc

    Oracle实验报告

    Oracle存储过程和函数(最详细包含emp 表实例操作,边看边操作)

    函数与存储过程相似,但函数必须返回一个值,而存储过程可以不返回。函数可以被用作查询的一部分,提升SQL语句的灵活性。 1. **创建函数**:使用`CREATE FUNCTION`语句定义函数,例如: ```sql CREATE OR REPLACE...

    GBase 8S 自定义存储过程和函数.doc

    与普通的SQL查询相比,存储过程有以下几个显著优点: 1. **模块化编程**:存储过程类似高级语言中的函数,可以被多个应用程序调用,实现了代码的模块化,提高代码的复用性,减少了重复编写相同功能的代码。 2. **...

    Mysql存储过程和函数区别介绍

    - **函数** 与存储过程类似,也是预编译的代码块,但其主要目的是为了计算或转换数据,然后返回一个单一的值。函数必须有返回值,且返回类型在声明时必须指定。它们在SQL查询中被广泛使用,作为表达式的一部分来...

    sqlserver 存储过程 函数 常用知识点

    在SQL Server中,存储过程和函数是数据库管理与开发中的重要组成部分,它们为数据库操作提供了高效、可重用和安全的途径。以下是关于SQL Server存储过程和函数的一些常用知识点: 1. **存储过程(Stored Procedures...

    mysql存储过程和存储函数

    mysql存储过程,存储函数练习,里面有详细代码,供大家参考

    第8章 存储过程、函数和包.ppt

    与存储过程类似,但函数必须有返回值,并且其返回类型在定义时指定。函数通常用于执行计算或返回特定值。例如,根据雇员ID获取雇员姓名可以定义为一个存储函数。 **包** 在Oracle中,包是将相关的存储过程和函数...

Global site tag (gtag.js) - Google Analytics