SQLServer之函数简介,入门必看
用户定义函数定义
与编程语言中的函数类似,SQL Server用户定义函数是接受参数、执行操作(例如复杂计算)并将操作结果以值的形式返回的例程。返回值可以是单个标量值或结果集。
用户定义函数准则
在函数中,将会区别处理导致语句被取消并继续执行模块(如触发器或存储过程)中的下一个语句的Transact-SQL错误。在函数中,上述错误会导致停止执行函数。接下来该操作导致取消调用该函数的语句。
BEGIN...END 块中的语句不能有任何副作用。函数副作用是指对具有函数外作用域(例如数据库表的修改)的资源状态的任何永久性更改。函数中的语句唯一能做的更改是对函数上的局部对象(如局部游标或局部变量)的更改。不能在函数中执行的操作包括:对数据库表的修改,对不在函数上的局部游标进行操作,发送电子邮件,尝试修改目录,以及生成返回至用户的结果集。
如果 CREATE FUNCTION 语句对在发出 CREATE FUNCTION 语句时不存在的资源产生副作用,SQL Server将执行该语句。但在调用函数时,SQL Server不执行此函数。
在查询中指定的函数的实际执行次数在优化器生成的执行计划间可能不同。示例为 WHERE 子句中的子查询调用的函数。子查询及其函数执行的次数会因优化器选择的访问路径的不同而异。
用户定义函数分类
标量函数
用户定义标量函数返回在 RETURNS 子句中定义的类型的单个数据值。对于内联标量函数,没有函数体;标量值是单个语句的结果。对于多语句标量函数,定义在 BEGIN...END 块中的函数体包含一系列返回单个值的Transact-SQL语句。返回类型可以是任何数据类型除外text,ntext,image,cursor,和timestamp。
表值函数
用户定义表值函数返回table数据类型。对于内联表值函数,没有函数主体;表是单个 SELECT 语句的结果集。
系统函数
SQL Server提供了许多系统函数,可用于执行各种操作。这些函数不能修改。有关详细信息,请参阅内置函数 (Transact-SQL)、系统存储函数 (Transact-SQL)和动态管理视图和函数 (Transact-SQL)。
内置函数
聚合函数
聚合函数对一组值执行计算,并返回单个值。在 select 列表或 SELECT 语句的 HAVING 子句中允许使用它们。可以将聚合与 GROUP BY 子句结合使用,来计算行类别的聚合。
使用 OVER 子句来计算特定范围内的值的聚合。OVER 子句不能跟在 GROUPING 或 GROUPING_ID 聚合后。
聚合函数对一组值执行计算,并返回单个值。除了COUNT外,聚合函数都会忽略 Null 值。
所有聚合函数均为确定性函数。换言之,每次使用一组特定的输入值调用聚合函数时,它们所返回的值都是相同的。有关函数确定性的详细信息,请参阅确定性函数和不确定性函数。
只能在以下位置将聚合函数作为表达式使用:
SELECT 语句的选择列表(子查询或外部查询)。
HAVING 子句。
分析函数
解析函数基于一组行计算聚合值。不过,与聚合函数不同,分析函数可能针对每个组返回多行。可以使用分析函数来计算移动平均线、运行总计、百分比或一个组内的前 N 个结果。
排名函数
排名函数为分区中的每一行返回一个排名值。根据所用函数的不同,某些行可能与其他行接收到相同的值。排名函数具有不确定性。
行集函数
行集函数 返回可在 SQL 语句中像表引用一样使用的对象。
标量函数
对单一值进行运算,然后返回单一值。只要表达式有效,即可使用标量函数。
系统存储函数
SQL Server提供了以下组的系统函数:Always On 可用性组函数、变更数据捕获函数、更改跟踪函数、据收集器函数、Filestream 和 FileTable 函数、托管备份函数、sys.fn_get_sql、sys.fn_MSxe_read_event_stream、sys.fn_stmt_sql_handle_from_sql_stmt、sys.fn_validate_plan_guide、sys.fn_xe_file_target_read_file、sys.fn_backup_file_snapshots、语义全文搜索函数、系统元数据函数、系统安全函数、系统跟踪函数。
动态管理视图函数
动态管理视图和函数返回可用于监视服务器实例的运行状况、诊断故障以及优化性能的服务器状态信息。
动态管理视图和函数分为两种类型:
服务器范围内的动态管理视图和函数。此类型需要具有该服务器的 VIEW SERVER STATE 权限。
数据库范围内的动态管理视图和函数。此类型需要具有该数据库的 VIEW DATABASE STATE 权限。
用户定义函数输入
用户定义函数采用零个或多个输入参数并返回标量值或表。一个函数最多可以有 1024 个输入参数。如果函数的参数有默认值,则调用该函数时必须指定 DEFAULT 关键字,才能获取默认值。此行为与在用户定义存储过程中具有默认值的参数不同,在后一种情况下,忽略参数同样意味着使用默认值。
用户定义函数输出
用户定义函数不支持输出参数。
标量函数返回的是一个数据类型值。
内联表值函数返回的是一个table。
系统函数用户执行指定操作,可以返回数据类型值或者table。
用户自定义函数应用场景
具有重复代码、功能和代码块的地方,应使用函数以使代码具有更好的可维护性、可重用性和更少的复杂性。
需要对表中数据进行简单处理,例如数学计算时可以考虑使用函数。
只有查询功能时应优先考虑视图,包含查询和其他操作的应优先考虑函数。
用户自定义函数优点
在SQL Server中使用用户定义函数有以下优点:
允许模块化程序设计。
只需创建一次函数并将其存储在数据库中,以后便可以在程序中调用任意次。用户定义函数可以独立于程序源代码进行修改。
执行速度更快。
与存储过程相似,Transact-SQL用户定义函数通过缓存计划并在重复执行时重用它来降低Transact-SQL代码的编译开销。这意味着每次使用用户定义函数时均无需重新解析和重新优化,从而缩短了执行时间。
和用于计算任务、字符串操作和业务逻辑的Transact-SQL函数相比,CLR 函数具有显著的性能优势。Transact-SQL函数更适用于数据访问密集型逻辑。
减少网络流量。
基于某种无法用单一标量的表达式表示的复杂约束来过滤数据的操作,可以表示为函数。然后,此函数便可以在 WHERE 子句中调用,以减少发送至客户端的数字或行数。
查询中的Transact-SQL用户定义函数只能针对单个线程执行(串行执行计划)。
用户自定义函数缺点
用户自定义函数不能用于执行一系列改变数据库状态的操作。
能在函数中使用的语句有严格限制:
不支持create、ALTER、drop等DDL(Data Definition Language)命令。
insert、delete、update只能用在临时表上。
不支持动态SQL。
不支持“不确定”的函数,比如常用的getdate。不确定函数是指输入参数相同,返回结果可能不同的函数。
原作者:小子pk了
原地址:https://www.cnblogs.com/vuenote/p/9945530.html
相关问答
联想拯救者y700 ,相机为什么打不开? - Microsoft Community[回答]我们了解到您关于Windows10无法打开相机的问题,您的这个问题一般是由于摄像头驱动出现问题导致的,建议您联系联想官方索取摄像头驱动程序进行更新...
相对应的数到是什么[回答]SetFsys=WScript.CreateObject("Scripting.FileSystemObject")msg1="十进制"&vbTab&...
笔记本相机出现错误代码0xa00f4271-ZOL问答3、您应该找到包含stream.sys的文件。如果不存在,则表示您的相机是在Windows7发布后开发的,这意味着它适用于当前的Windows10操作系统。但是,如果文件在列表...
hysys中提示" stream with negative composition",如 ... -盖...用hysysv7.2模拟脱己烷塔,输入组分分率时提示"streamwithnegativecomposition",如何解决产品量不能都作为规定。已解决,需手动添加组分库...
c#如何保存图片? - 懂得//可能要5261添加对程序集System.Drawing.dll的引用4102usingSystem;usingSystem.IO;usingSystem.Drawing;usingSysMemo...
Python里面有什么好用且有趣的模块?在github里面找到的python框架,库,软件和资源的精选列表管理面板管理界面的库。ajenti-您的服务器应得的管理面板。django-grappelli-DjangoAdm...
aspen hysys 管线流速及管径计算问题-盖德问答-化工人互助问...压降选多少?跟什么相关,计算类型怎么使用。上面的schedule是啥意思呢谢谢啦schdule就是壁厚等级,sch40,sch80、sch160最常用,可以看一下配...
python log.conf文件如何配置?您可以使用Python的logging.config模块来配置log.conf文件。以下是一个示例,其中log.conf文件包含以下内容:```[loggers]keys=root,sample...
Aspen plus和HYSYS能否模拟气液固三相平衡系统?-盖德问答-化...选择固体当然没问题,你说的是模拟三相平衡系统,选择不一定就可以模拟你说的问题,这个选择是在后期做什么筛分,旋风分离用的,不能做g-l-s三相平衡,看...
HYSYS相图Curve数据-盖德问答-化工人互助问答社区这个是帮助上的解释哦ptenvelopethevapour-liquidenvelopeforaqualityof1.0automaticallyappears.thisi...