数据库中存储过程和函数的区别是什么用自己的话回答。

数据库中存储过程和函数的区别是什么用自己的话回答。,第1张

存储过程:可以进行增删查改dml *** 作,甚至可以进行建表等ddl *** 作;不能return返回值,可以用out参数返回值。用exec 过程名 的方法调用。

函数,可以return返回值;一般来说,只能进行select *** 作,不能进行增删改,也不能进行ddl *** 作。可以通过赋值的方式调用,也可以在sql语句中使用。

一、含义不同

1、存储过程:存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。

2、函数:是由一个或多个 SQL 语句组成的子程序,可用于封装代码以便重新使用。 函数限制比较多,如不能用临时表,只能用表变量等

二、使用条件不同

1、存储过程:可以在单个存储过程中执行一系列 SQL 语句。而且可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。

2、函数:自定义函数诸多限制,有许多语句不能使用,许多功能不能实现。函数可以直接引用返回值,用表变量返回记录集。但是,用户定义函数不能用于执行一组修改全局数据库状态的 *** 作。

三、执行方式不同

1、存储过程:存储过程可以返回参数,如记录集,函数只能返回值或者表对象。存储过程的参数有in,out,inout三种,存储过程声明时不需要返回类型。

2、函数:函数参数只有in,而函数需要描述返回类型,且函数中必须包含一个有效的return语句。

参考资料链接:百度百科-存储过程

参考资料链接:百度百科-函数

1:右键单击登录名Test的属性

2: 在服务器角色里面选择"public"服务器角色。

3:在用户映射选项当中,选择"db_datareader"、"db_datawriter"、"public"三个数据库角色成员。

此时,已经实现了拥有DML *** 作权限,如果需要拥有存储过程和函数的执行权限,必须使用GRANT语句去授权,一个生产库的存储过程和函数加起来成千上百,如果手工执行的话,那将是一个辛苦的体力活,而我手头有十几个库,所以必须用脚本去实现授权过程。下面是我写的一个存储过程,亮点主要在于会判断存储过程、函数是否已经授予了EXE或SELECT权限给某个用户。这里主要用到了安全目录试图sysdatabase_permissions,例如,数据库里面有个存储过程dbosp_authorize_right,如果这个存储过程授权给Test用户了话,那么在目录试图sysdatabase_permissions里面会有一条记录,如下所示:

如果我将该存储过程授予EXEC权限给TEST1,那么

GRANT EXEC ON dbosp_diskcapacity_cal TO Test;

GRANT EXEC ON dbosp_diskcapacity_cal TO Test1;

SELECT FROM syssysusers WHERE name ='Test' OR name ='Test1'

其实grantee_principal_id代表向其授予权限的数据库主体 ID ,所以我就能通过上面两个视图来判断存储过程是否授予执行权限给用户Test与否,同理,对于函数也是如此,存储过程如下所示,其实这个存储过程还可以扩展,如果您有特殊的需要的话。

复制代码 代码如下:

Code Snippet

USE MyAssistant;

GO

SET ANSI_NULLS ON;

GO

SET QUOTED_IDENTIFIER ON

GO

IF EXISTS(SELECT 1 FROM sysobjects WHERE id=OBJECT_ID(N'sp_authorize_right') AND OBJECTPROPERTY(id, 'IsProcedure') =1)

DROP PROCEDURE sp_authorize_right;

GO

--=========================================================================================================

-- ProcedureName : sp_authorize_right

-- Author : Kerry

-- CreateDate : 2013-05-10

-- Blog : >

1)自定义函数中不能调用存储过程,如果调用了,函数可以顺利创建,但是调用函数会出错

2)自定义函数中不能创建表,删除表,插入表数据

解决办法:

可以先把存储过程返回的结果插入到临时表,然后在函数里调用临时表,或者运用内置函数,或者使用复杂的联合查询实现想要的结果

关键字:procedure 例子: SQL> create [or replace] procedure procedure_name is begin --开始执行 insert into test('10001','Visket'); end; / 以上 *** 作就能为test表添加一条信息执行存储过程procedure用的命令是exec 记住存储过程中,语句结尾一定要有分号

SQL的调用可以分为函数和存储过程。

个人理解,其实函数和存储过程是相似的,至少在引用的时候跟函数很是一样。或者干脆把存储过程理解为另一种函数,另一种经过优化的函数。它的优点在于,存储过程在被编译后会被直接保存在数据库中,成为数据库的一部分,以后就可以反复调用,运行速度快,效率高,这些是函数做不到的。

存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象。

种类

1系统存储过程

以sp_开头,用来进行系统的各项设定取得信息相关管理工作。

2本地存储过程

用户创建的存储过程是由用户创建并完成某一特定功能的存储过程,事实上一般所说的存储过程就是指本地存储过程。

3临时存储过程

分为两种存储过程:

一是本地临时存储过程,以井字号(#)作为其名称的第一个字符,则该存储过程将成为一个存放在tempdb数据库中的本地临时存储过程,且只有创建它的用户才能执行它;

二是全局临时存储过程,以两个井字号(##)号开始,则该存储过程将成为一个存储在tempdb数据库中的全局临时存储过程,全局临时存储过程一旦创建,以后连接到服务器的任意用户都可以执行它,而且不需要特定的权限。

4远程存储过程

在SQL Server2005中,远程存储过程(Remote Stored Procedures)是位于远程服务器上的存储过程,通常可以使用分布式查询和EXECUTE命令执行一个远程存储过程。

5扩展存储过程

扩展存储过程(Extended Stored Procedures)是用户可以使用外部程序语言编写的存储过程,而且扩展存储过程的名称通常以xp_开头。

一、多数指令是相同的,包括创建和修正存储过程的指令。二、很多细微的指令有不同,具体如下(不仅):1mysql支持enum,和set类型,sqlserver不支持2mysql不支持nchar,nvarchar,ntext类型3mysql的递增语句是AUTO_INCREMENT,而mssql是identity(1,1)MYSQL:createtablebasic(idintkeyauto_increment,namevarchar(20));MSSQL:createtablebasic(idintidentity(1,1),namevarchar(20))4msms默认到处表创建语句的默认值表示是((0)),而在mysql里面是不允许带两括号的5mysql需要为表指定存储类型6mssql识别符是[],[type]表示他区别于关键字(可选用来包含表名、字段名),但是mysql却是`(重音符,也就是按键1左边的那个符号)7mssql支持getdate()方法获取当前时间日期,但是mysql里面可以分日期类型和时间类型,获取当前日期是cur_date(),当前完整时间是now()函数8mssql不支持replaceinto语句,但是在最新的sql20008里面,也支持merge语法9mysql支持insertintotable1sett1=‘’,t2=‘’,但是mssql不支持这样写10mysql插入多行支持这样写insertintotabl1values(1,1),(1,1),(1,1),(1,1),(1,1),(1,1),(1,1)MSSQL不支持11mssql不支持limit语句,是非常遗憾的,只能用top取代limt0,N,row_number()over()函数取代limitN,M12mysql在创建表时要为每个表指定一个存储引擎类型,而mssql只支持一种存储引擎13mysql不支持默认值为当前时间的datetime类型(mssql很容易做到),在mysql里面是用timestamp类型14mssql里面检查是否有这个表再删除,需要这样:ifexists(selectfromdbosysobjectswhereid=object_id(N'uc_newpm')andOBJECTPROPERTY(id,N'IsUserTable')=1)但是在mysql里面只需要DROPTABLEIFEXISTScdb_forums;15mysql支持无符号型的整数,那么比不支持无符号型的mssql就能多出一倍的最大数存储16mysql不支持在mssql里面使用非常方便的varchar(max)类型,这个类型在mssql里面既可做一般数据存储,也可以做blob数据存储17mysql创建非聚集索引只需要在创建表的时候指定为key就行,比如:KEYdisplayorder(fid,displayorder)在mssql里面必须要:createuniquenonclusteredindexindex_uc_protectedmembers_username_appidondbouc_protectedmembers(usernameasc,appidasc)18mysqltext字段类型不允许有默认值19mysql的一个表的总共字段长度不超过65XXX。20一个很表面的区别就是mysql的安装特别简单,而且文件大小才110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是21mysql的管理工具有几个比较好的,mysql_front,和官方那个套件,不过都没有SSMS的使用方便,这是mysql很大的一个缺点。22mysql的存储过程只是出现在最新的版本中,稳定性和性能可能不如mssql。23同样的负载压力,mysql要消耗更少的CPU和内存,mssql的确是很耗资源。24php连接mysql和mssql的方式都差不多,只需要将函数的mysql替换成mssql即可。25mysql支持date,time,year类型,mssql到2008才支持date和time。26变量赋值MYsql:变量赋值SELECT@min_price:=MIN(price),@max_price:=MAX(price)FROMshopMSsql:变量赋值SELECT@min_price=MIN(price),@max_price=MAX(price)FROMshop三、总的来说,如果是简单的存储过程代码,要修改,不会太难。如果是复杂的系统,要移植会很难很难。

以上就是关于数据库中存储过程和函数的区别是什么用自己的话回答。全部的内容,包括:数据库中存储过程和函数的区别是什么用自己的话回答。、存储过程和函数的区别、sqlSQL数据库怎么批量为存储过程/函数授权等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10189019.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存