除了使用系统提供的函数外,用户还可以根据需要自定义函数。用户自定义函数是 SQL Server 2000 新增的数据库对象,是 SQL Server 的一大改进。与编程语言中的函数类似,Microsoft SQL Server 用户定义函数是接受参数、执行操作(例如复杂计算)并将操作结果以值的形式返回的例程。返回值可以是单个标量值或表变量结果集。

  用户自定义函数不能用于执行一系列改变数据库状态的操作,但它可以像系统函数一样在查询或存储过程等的程序段中使用,也可以像存储过程一样通过 EXECUTE 命令来执行。

在 SQL Server 中根据函数返回值形式的不同将用户自定义函数分为三种类型

(1)标量函数

(2)内联表值函数

(3)多语句表值函数

注意:与编程语言中的函数不同的是,SQL Server 自定义函数必须具有返回值。

标量函数

标量函数返回一个确定类型的标量值,其返回值类型为除TEXT、NTEXT、IMAGE、CURSOR、TIMESTAMP和TABLE类型外的其它数据类型。函数体语句定义在BEGIN-END语句内。在 RETURNS 子句中定义返回值的数据类型,并且函数的最后一条语句必须为Return语句。创建标量函数的格式:

Create Function 函数名(参数)

Returns 返回值数据类型

[With {Encryption|Schemabinding}]

[AS]

BEGIN

SQL语句(必须有Return子句)
END

举例:

CREATE FUNCTION dbo.Max
(
    @a int,
    @b int
)
RETURNS int AS 
BEGIN
    DECLARE @max int
    IF @a>@b  SET  @max=@a
    ELSE   SET  @max=@b
    Return @max
END

调用标量函数

可以在 T-SQL 语句中允许使用标量表达式的任何位置调用返回标量值(与标量表达式的数据类型相同)的任何函数。必须使用至少由两部分组成名称的函数来调用标量值函数,即架构名.对象名,如dbo.Max(12,34)。

内联表值函数

内联表值型函数以表的形式返回一个返回值,即它返回的是一个表。内联表值型函数没有由BEGIN-END 语句括起来的函数体。其返回的表是由一个位于 RETURN 子句中的 SELECT 命令从数据库中筛选出来。内联表值型函数功能相当于一个参数化的视图

Create Function 函数名(参数)

RETURNS table

[with {Encryption|Schemabinding}]

AS

Return(一条SQL语句)

举例:

CREATE FUNCTION func (@id char(8))
RETURNS TABLE
AS
RETURN
(
    SELECT * FROM student WHERE SID = @id

)

调用内联表值函数:调用时不需指定架构名,如select * from func('51300521')

多语句表值函数

多语句表值函数可以看作标量函数和内联表值函数的结合体。它的返回值是一个表,但它和标量型函数一样有一个用 BEGIN-END 语句括起来的函数体,返回值的表中的数据是由函数体中的语句插入的。由此可见,它可以进行多次查询,对数据进行多次筛选与合并,弥补了内联表值函数的不足。

Create Function 函数名(参数)

RETURNS 表变量名 (表变量字段定义)

[with {Encryption|Schemabinding}]

AS

BEGIN

SQL语句

Return

END

举例:
CREATE FUNCTION func(@selection int)
RETURNS @table TABLE
(
    SID char(4) primary key not null,
    SName nvarchar(4) null
)
AS
BEGIN
    IF @selection = 0
        INSERT INTO @table (SELECT SID,SName FROM student0)
    ELSE 
        INSERT INTO @table (SELECT SID,SName FROM student1)
    Return
END

调用多语句表值函数:和调用内联表值函数一样,调用时不需制定架构名。

注意:Schemabinding用于将函数绑定到它引用的对象上。函数一旦绑定,则不能删除、修改,除非删除绑定。

SQL Server--用户自定义函数相关推荐

  1. SQL Server用户自定义函数

    用户自定义函数不能用于执行一系列改变数据库状态的操作,但它可以像系统 函 数一样在查询或存储过程等的程序段中使用,也可以像存储过程一样通过 EXECUTE 命令来执行.在 SQL Server 中根据 ...

  2. SQL SERVER 用户自定义函数(UDF)深入解析

    本文内容概要: UDF 概念.原理.优缺点.UDF 的分类 详细讲述3种 UDF 的创建.调用方法以及注意事项 UDF 的实践建议 基本原理: UDF:user-defined functions,用 ...

  3. SQL SERVER 用户自定义函数如何定义.

    CREATE   FUNCTION     创建用户定义函数,它是返回值的已保存的   Transact-SQL   例程.用户定义函数不能用于执行一组修改全局数据库状态的操作.与系统函数一样,用户定 ...

  4. php server自定义函数,php:SQL Server用户自定义的函数种类详解

    关于SQL Server用户自定义的函数,有标量函数.表值函数(内联表值函数.多语句表值函数)两种. 题外话,可能有部分朋友不知道SQL Serve用户自定义的函数应该是写在哪里,这里简单提示一下,在 ...

  5. SQL之用户自定义函数

    关于SQL Server用户自定义的函数,有标量函数.表值函数(内联表值函数.多语句表值函数)两种. 题外话,可能有部分朋友不知道SQL Serve用户自定义的函数应该是写在哪里,这里简单提示一下,在 ...

  6. sql server 自定义函数的使用

    sql server 自定义函数的使用 自定义函数 用户定义自定义函数像内置函数一样返回标量值,也可以将结果集用表格变量返回 用户自定义函数的类型: 标量函数:返回一个标量值 表格值函数{内联表格值函 ...

  7. SQL Server CONVERT() 函数,Date 函数

    From: http://www.w3school.com.cn/sql/func_convert.asp 定义和用法 CONVERT() 函数是把日期转换为新数据类型的通用函数. CONVERT() ...

  8. SQL Server日期函数集合

    SQL Server日期函数集合--1:获取系统日期和时间值函数 --getdate() SELECT GETDATE() AS 'today' --getutcdate() SELECT GETUT ...

  9. sql server charindex函数和patindex函数详解(转)

    charindex和patindex函数常常用来在一段字符中搜索字符或字符串.假如被搜索的字符中包含有要搜索的字符,那么这两个函数返回一个非零的整数,这个整数是要搜索的字符在被搜索的字符中的开始位数. ...

  10. Sql Server REPLACE函数的使用;SQL中 patindex函数的用法

    Sql Server REPLACE函数的使用 REPLACE 用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式. 语法 REPLACE ( ''string_replace1' ...

最新文章

  1. JMH和Arthas定位问题的案例分享
  2. Less 常用基础知识
  3. LeetCode集锦(八) - 第26题 Remove Duplicates From Sorted Array
  4. c语言中的文件类型只有文本文件一种,C语言中的文件类型只有哪两种_后端开发...
  5. Visual Studio Code设置中文包/配置中文语言
  6. 《技术的本质》2月24日part1
  7. [Python图像处理] 二十六.图像分类原理及基于KNN、朴素贝叶斯算法的图像分类案例
  8. 【机器学习】集成学习知识点总结一
  9. 超详细Centos6.5文本模式安装步骤
  10. 高性能 Socket 组件 HP-Socket v3.1.3 正式发布
  11. python 多and or执行顺序
  12. 评分卡模型开发(一)--用户数据缺失值处理
  13. eclipse 添加jar (servlet api)
  14. 浪曦_Struts2应用开发系列_第2讲.Struts2的类型转换-学习笔记
  15. vue做混合式app_基于vue2.0开发混合app的思考
  16. 免驱 usb有线网卡_2020年末台式机amp;笔记本无线网卡最全选购指南amp;攻略,打造极致WIFI体验!...
  17. java else 语法错误_在else处语法错误,删除此令牌
  18. php无法运行,php不执行是什么原因造成的
  19. vue校验输入框不能有中文
  20. 什么是服务器安全性?

热门文章

  1. C++ Fermat‘s little theorem费马小定理寻找模逆实现算法(附完整源码)
  2. C++实现trie tree字典树(附完整源码)
  3. QT的QJSValue类的使用
  4. QML基础类型之data
  5. C++继承同名成员处理方式
  6. java 连接池技术_java数据库连接池技术原理(浅析)
  7. java大整数的加减乘除_关于大整数的加减乘除求余运算 java
  8. B09_NumPy迭代数组(控制遍历顺序,修改数组中元素的值,使用外部循环,广播迭代)
  9. Oracle中PLSQL中一个例外的写法
  10. 窗口分析函数_5_计算累加乘