当前位置:首页 » 存储配置 » 存储过程自定义函数

存储过程自定义函数

发布时间: 2023-09-27 09:49:31

① 关于sql的临时表、自定义函数、储存过程的问题

如果你有编程基础的话
那么自定义函数和存储过程的区别,就是程序里面函数与过程的区别,函数只是为了实现某个功能,而过程是为了实现某个流程。
至于使用的时间
这个跟你的实际需求有关系的,一般系统带的函数就能满足需求。
存储过程这个看你项目的访问量,访问量小的话
如果是快速开发不会用到存储过程
直接在程序里面写SQL语句就OK。如果访问量大,那么必须使用存储过程。
临时表的好处是它可以是只对某个用户的表,而且不具有实际意义,并且可以定义自动销毁的临时表。跟视图在某种情况下有相同之处。
临时表的试用时间也是跟你的需求有关系的。
创建语句差不多
都是T-SQL语句。
最后一个问题你得搜索一下才知道,一般情况下定义的临时表都是自动销毁的,使用完毕会drop掉(节省资源,如果是#开头的临时表
系统会自动在使用完毕后销毁掉。)

② 存储过程和函数的区别

一、含义不同

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

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

二、使用条件不同

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

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

三、执行方式不同

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

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

③ SQL中存储过程与自定义函数怎么互相转换

--(1):输入一个数,返回结果为这个数加1
--存储过程:
create procere pro_test
@input int,
@output int output
as
set @output = @input+1
go

--函数:
create function f_test(@input int)
returns int
as
begin
declare @output int
set @output = @input+1
return @output
end

--(2)输入一个数,返回一个结果集
--存储过程:
create procere pro_test2
@input int
as
select * from sysobjects where id = @input
go

--函数:
create function f_test2(@input int)
returns table
as
return (select * from sysobjects where id = @input)

④ sqlserver存储过程如何调用自定义函数

返回单个值的函数, 可以当变量用, 比如 select dbo.函数名(参数1, 参数2, ...) from ...where abc = dbo.函数名(参数1, 参数2...)

返回表的函数, 可以当数据表来使用, 比如 select * from dbo.函数名(参数1, 参数2, ...)

⑤ sql数据库中的自定义函数可以调用存储过程

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

2)自定义函数中不能创建表,删除表,插入表数据
解决办法:

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

⑥ 存储过程和自定义函数的区别

SQL中存储过程和自定义函数的区别
2008年12月19日来源:233网校评论 分享到 我的做题记录

刚开始学SQL,很快就发现存储过程和数据库自定义函数之间貌似有很多的相同点,所以把其差别简单做下记录,以备以后查阅:
存储过程:
存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。
存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。
可以出于任何使用 SQL 语句的目的来使用存储过程,它具有以下优点:
1、可以在单个存储过程中执行一系列 SQL 语句。
2、可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。
3、存储过程在创建时即在服务器上进行编译,所以执行起来比单个 SQL 语句快。
用户定义函数:
Microsoft SQL Server 2000 允许创建用户定义函数。与任何函数一样,用户定义函数是可返回值的例程。根据所返回值的类型,每个用户定义函数可分成以下三个类别:
1、返回可更新数据表的函数
如果用户定义函数包含单个 Select 语句且该语句可更新,则该函数返回的表格格式结果也可以更新。
2、返回不可更新数据表的函数
如果用户定义函数包含不止一个 Select 语句,或包含一个不可更新的 Select 语句,则该函数返回的表格格式结果也不可更新。
3、返回标量值的函数
用户定义函数可以返回标量值。
存储过程
功能强大,限制少
不能直接引用返回值
用select语句返回记录集
自定义函数
诸多限制,有许多语句不能使用,许多功能不能实现
可以直接引用返回值
用表变量返回记录集

热点内容
用户上传伴奏 发布:2024-11-30 09:35:33 浏览:263
sql服务器配置失败 发布:2024-11-30 09:35:21 浏览:910
php从传智播客 发布:2024-11-30 09:33:47 浏览:965
硬盘录像机外接存储服务器 发布:2024-11-30 09:27:18 浏览:993
雅视修改密码为什么失败 发布:2024-11-30 09:25:46 浏览:966
安卓照片大小怎么改100k内 发布:2024-11-30 09:20:39 浏览:431
ups系统如何配置网络 发布:2024-11-30 09:06:14 浏览:58
怎么看pppoe密码 发布:2024-11-30 08:35:35 浏览:510
sandisk16gb存储卡 发布:2024-11-30 08:34:42 浏览:954
eclipsejava反编译 发布:2024-11-30 08:34:37 浏览:900