热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

sql2k中新增加的Function的sqlbook的帮助

CREATEFUNCTION创立用户定义函数,它是返回值的已保留的Transact-SQL例程。用户定义函数不能用于履行一组修正全局数据库状态的把持。与系统函数一样,用户定义函数可以从查询中唤醒

CREATE FUNCTION

创立用户定义函数,它是返回值的已保留的 Transact-SQL 例程。用户定义函数不能用于履行一组修正全局数据库状态的把持。与系统函数一样,用户定义函数可以从查询中唤醒调用。也可以像存储过程一样,通过 EXECUTE 语句履行。

用户定义函数用 ALTER FUNCTION 修正,用 DROP FUNCTION 除往。

语法

标量函数

以下为引用的内容:

CREATE FUNCTION [ owner_name.] function_name
( [ { @parameter_name [AS] scalar_parameter_data_type [ = default ] } [ ,...n ] ] )

RETURNS scalar_return_data_type

[ WITH [ [,] ...n] ]

[ AS ]

BEGIN
function_body
RETURN scalar_expression
END

内嵌表值函数

以下为引用的内容:

CREATE FUNCTION [ owner_name.] function_name
( [ { @parameter_name [AS] scalar_parameter_data_type [ = default ] } [ ,...n ] ] )

RETURNS TABLE

[ WITH [ [,] ...n ] ]

[ AS ]

RETURN [ ( ] select-stmt [ ) ]

多语句表值函数

以下为引用的内容:

CREATE FUNCTION [ owner_name.] function_name
( [ { @parameter_name [AS] scalar_parameter_data_type [ = default ] } [ ,...n ] ] )

RETURNS @return_variable TABLE

[ WITH [ [,] ...n ] ]

[ AS ]

BEGIN
function_body
RETURN
END

::=
{ ENCRYPTION | SCHEMABINDING }

::=
( { column_definition | table_constraint } [ ,...n ] )

参数

owner_name

拥有该用户定义函数的用户 ID 的名称。owner_name 必需是现有的用户 ID。

function_name

用户定义函数的名称。函数名称必需符合标识符的规矩,对其所有者来说,该名称在数据库中必需是唯一的。

@parameter_name

用户定义函数的参数。CREATE FUNCTION 语句中可以声明一个或多个参数。函数最多可以有 1,024 个参数。函数履行时每个已声明参数的值必需由用户指定,除非该参数的默认值已经定义。 假如函数的参数有默认值,在调用该函数时必需指定"default"要害字才干获得默认值。这种行动不同于存储过程中有默认值的参数,在存储过程中省略参数也意味着应用默认值。

应用 @ 符号作为第一个字符来指定参数名称。参数名称必需符合标识符的规矩。每个函数的参数仅用于该函数本身;雷同的参数名称可以用在其它函数中。参数只能代替常量;而不能用于代替表名、列名或其它数据库对象的名称。

scalar_parameter_data_type

参数的数据类型。所有标量数据类型(包含 bigint 和 sql_variant)都可用作用户定义函数的参数。不支撑 timestamp 数据类型和用户定义数据类型。不能指定非标量类型(例如 cursor 和 table)。

scalar_return_data_type

是标量用户定义函数的返回值。scalar_return_data_type 可以是 SQL Server 支撑的任何标量数据类型(text、ntext、image 和 timestamp 除外)。

scalar_expression

指定标量函数返回的标量值。

TABLE

指定表值函数的返回值为表。

在内嵌表值函数中,通过单个 SELECT 语句定义 TABLE 返回值。内嵌函数没有相干联的返回变量。

在多语句表值函数中,@return_variable 是 TABLE 变量,用于存储和累积应作为函数值返回的行。

function_body

指定一系列 Transact-SQL 语句定义函数的值,这些语句合在一起不会产生副作用。function_body 只用于标量函数和多语句表值函数。

在标量函数中,function_body 是一系列合起来求得标量值的 Transact-SQL 语句。

在多语句表值函数中,function_body 是一系列填充表返回变量的 Transact-SQL 语句。

select-stmt

是定义内嵌表值函数返回值的单个 SELECT 语句。

ENCRYPTION

指出 SQL Server 加密包含 CREATE FUNCTION 语句文本的系统表列。应用 ENCRYPTION 可以避免将函数作为 SQL Server 复制的一部分宣布。

SCHEMABINDING

指定将函数绑定到它所引用的数据库对象。假如函数是用 SCHEMABINDING 选项创立的,则不能更改(应用 ALTER 语句)或除往(应用 DROP 语句)该函数引用的数据库对象。

函数与其所引用对象的绑定关系只有在产生以下两种情况之一时才被解除:

除往了函数。

在未指定 SCHEMABINDING 选项的情况下更改了函数(应用 ALTER 语句)。

只有在满足以下条件时,函数才干绑定到架构:

该函数所引用的用户定义函数和视图也已绑定到架构。

该函数所引用的对象不是用两部分名称引用的。

该函数及其引用的对象属于同一数据库。

履行 CREATE FUNCTION 语句的用户对所有该函数所引用的数据库对象都具有 REFERENCES 权限。

假如不符合以上条件,则指定了 SCHEMABINDING 选项的 CREATE FUNCTION 语句将失败。

注释

用户定义函数为标量值函数或表值函数。假如 RETURNS 子句指定一种标量数据类型,则函数为标量值函数。可以应用多条 Transact-SQL 语句定义标量值函数。

假如 RETURNS 子句指定 TABLE,则函数为表值函数。根据函数主体的定义方法,表值函数可分为行内函数或多语句函数。

假如 RETURNS 子句指定的 TABLE 不附带列的列表,则该函数为行内函数。行内函数是应用单个 SELECT 语句定义的表值函数,该语句组成了函数的主体。该函数返回的表的列(包含数据类型)来自定义该函数的 SELECT 语句的 SELECT 列表。

假如 RETURNS 子句指定的 TABLE 类型带有列及其数据类型,则该函数是多语句表值函数。

多语句函数的主体中答应应用以下语句。未在下面的列表中列出的语句不能用在函数主体中。

赋值语句。

把持流语句。

DECLARE 语句,该语句定义函数局部的数据变量和游标。

SELECT 语句,该语句包含带有表达式的选择列表,其中的表达式将值赋予函数的局部变量。

游标把持,该把持引用在函数中声明、打开、封闭和开释的局部游标。只答应应用以 INTO 子句向局部变量赋值的 FETCH 语句;不答应应用将数据返回到客户真个 FETCH 语句。

INSERT、UPDATE 和 DELETE 语句,这些语句修正函数的局部 table 变量。

EXECUTE 语句调用扩大存储过程。

函数的断定性和副作用

函数可以是断定的或不断定的。假如任何时候用一组特定的输进值调用函数时返回的成果总是雷同的,则这些函数为断定的。假如每次调用函数时即应用的是雷同的一组特定输进值,返回的成果总是不同的,则这些函数为不断定的。

不断定的函数会产生副作用。副作用是更改数据库的某些全局状态,比如更新数据库表或某些外部资源,如文件或网络等(例如,修正文件或发送电子邮件消息)。


推荐阅读
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
  • 当面临数据库清理任务时,若无删除或重建数据库的权限,可以通过编写SQL脚本来实现批量删除用户自定义的数据表和存储过程。本文将详细介绍如何构造这样的SQL脚本。 ... [详细]
  • PySpark实战:高效使用DataFrame超越RDD
    本文深入探讨了PySpark中DataFrame的使用方法及其相对于传统RDD的优势,旨在帮助开发者更好地理解和利用这一强大工具。 ... [详细]
  • 本文提供了一套实用的方法论,旨在帮助开发者构建能够应对高并发请求且易于扩展的Web服务。内容涵盖了服务器架构、数据库管理、缓存策略以及异步处理等多个方面。 ... [详细]
  • 本文详细探讨了如何在 SparkSQL 中创建 DataFrame,涵盖了从基本概念到具体实践的各种方法。作为持续学习的一部分,本文将持续更新以提供最新信息。 ... [详细]
  • yikesnews第11期:微软Office两个0day和一个提权0day
    点击阅读原文可点击链接根据法国大选被黑客干扰,发送了带漏洞的文档Trumps_Attack_on_Syria_English.docx而此漏洞与ESET&FireEy ... [详细]
  • 开发笔记:由数据库某字段存数组引发的json_encode/serialize思考
    开发笔记:由数据库某字段存数组引发的json_encode/serialize思考 ... [详细]
  • 深入解析:OpenShift Origin环境下的Kubernetes Spark Operator
    本文探讨了如何在OpenShift Origin平台上利用Kubernetes Spark Operator来管理和部署Apache Spark集群与应用。作为Radanalytics.io项目的一部分,这一开源工具为大数据处理提供了强大的支持。 ... [详细]
  • 掌握Mosek矩阵运算,轻松应对优化挑战
    本篇文章继续深入探讨Mosek学习笔记系列,特别是矩阵运算部分,这对于优化问题的解决至关重要。通过本文,您将了解到如何高效地使用Mosek进行矩阵初始化、线性代数运算及约束域的设定。 ... [详细]
  • 递归编程不仅是一种优雅的技术,还能让复杂的算法变得简洁高效。尤其在使用如Scala等支持函数式编程的语言时,递归更是不可或缺。本文将通过一个具体的例子,探讨递归的深层魅力。 ... [详细]
  • 本文介绍了一款基于Spark和Scala开发的应用程序,该应用通过配置单元作为输入,经过Spark处理层进行批处理操作,最终数据存储于Cassandra数据库中。文章探讨了如何实现该应用的测试自动化,包括业务逻辑测试、集成测试、用户验收测试(UAT)及回归测试。 ... [详细]
  • window下kafka的安装以及测试
    目录一、安装JDK(需要安装依赖javaJDK)二、安装Kafka三、测试参考在Windows系统上安装消息队列kafka一、安装JDKÿ ... [详细]
  • 本文深入探讨了Scala中的隐式转换机制,包括其在类扩展、隐式解析规则以及隐式参数和上下文绑定等方面的应用。通过具体示例,详细解释了如何利用隐式转换增强类的功能。 ... [详细]
  • 本文详细介绍了如何配置Apache Flume与Spark Streaming,实现高效的数据传输。文中提供了两种集成方案,旨在帮助用户根据具体需求选择最合适的配置方法。 ... [详细]
author-avatar
我是来工作的程_586
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有