储过程和用户自定义函数的区别
来源:互联网 发布:js获取当前设备宽度 编辑:程序博客网 时间:2024/06/05 09:44
常常有人问存储过程和用户自定义函数的区别究竟是什么,在网络上尝试搜索,却没见到十分全的总结,于是自己做个总结:
Procedure:
- CREATE { PROC | PROCEDURE } [schema_name.] procedure_name [ ; number ]
- [ { @parameter [ type_schema_name. ] data_type }
- [ VARYING ] [ = default ] [ OUT | OUTPUT ] [READONLY]
- ] [ ,...n ]
- [ WITH <procedure_option> [ ,...n ] ]
- [ FOR REPLICATION ]
- AS { <sql_statement> [;][ ...n ] | <method_specifier> }
- [;]
- <procedure_option> ::=
- [ ENCRYPTION ]
- [ RECOMPILE ]
- [ EXECUTE AS Clause ]
- <sql_statement> ::=
- { [ BEGIN ] statements [ END ] }
- <method_specifier> ::=
- EXTERNAL NAME assembly_name.class_name.method_name
Function:
- CREATE FUNCTION [ schema_name. ] function_name
- ( [ { @parameter_name [ AS ][ type_schema_name. ] parameter_data_type
- [ = default ] [ READONLY ] }
- [ ,...n ]
- ]
- )
- RETURNS return_data_type
- [ WITH <function_option> [ ,...n ] ]
- [ AS ]
- BEGIN
- function_body
- RETURN scalar_expression
- END
- [ ; ]
区别:
1.嵌套
function:无限制
sp:最多32层
2.改数据操作
function:不支持
sp:支持
3.结果返回
function:可以返回标量值,返回表变量(表甚至可以定义名字) 具有不确定性,必须返回
sp:并不一定需要返回,可返回记录集。
户定义函数不能用于执行一组修改全局数据库状态的操作
4.是否可以使用非确定函数
function:不允许在用户定义函数主体中内置非确定函数。
sp:可以使用非确定函数。
5.返回值引用
function:其返回值可以被直接引用
sp:其返回值不能被直接引用
6.调用
function:在其他语句中调用select
sp:EXEC
7.是否可以使用out参数
function:function没有out参数,但是可以有返回值.
sp:可以out参数
- 储过程和用户自定义函数的区别
- SQLServer 2000中,存储过程和用户自定义函数具体的区别
- SQLServer 2000中,存储过程和用户自定义函数具体的区别??
- 存储过程和自定义函数的区别
- 存储过程和自定义函数的区别
- 存储过程和自定义函数的区别(归纳)
- SqlServer Dev(1) - 存储过程和自定义函数的区别
- SQL中存储过程和自定义函数的区别
- (转)存储过程和自定义函数的区别
- mysql中自定义函数和存储过程的几个区别
- SQL中存储过程和自定义函数的区别
- 存储过程和触发器以及自定义函数的区别
- SQl中的UDF(用户自定义函数)与存储过程的区别、优点
- 存储过程与自定义函数的区别
- 存储过程、触发器和用户自定义函数实验(用户自定义函数)
- SQL SErver存储过程和用户自定义函数UDF
- 存储过程、触发器和用户自定义函数实验2、触发器
- 用户控件和自定义控件的区别
- How to Cheat at IIS 7 Server Administration
- 一朝天子一朝臣
- C++存储类的不解
- Simply JavaScript
- Expert SQL Server 2005 Integration Services
- 储过程和用户自定义函数的区别
- Beginning SharePoint 2007: Building Team Solutions with MOSS 2007
- 查找第N行数据
- RGB和HSV颜色空间的快速近似转换算法
- ubuntu 下的 vmware tool 安装 !
- 弹出窗口,页面背景逐渐变为半透明
- 简单的ftp 自动上传脚本
- 断言概述
- VS文件自动格式化