是否可以在用户定义的函数中插入列作为参数?

Posted

技术标签:

【中文标题】是否可以在用户定义的函数中插入列作为参数?【英文标题】:Is it possible to insert a column as a parameter in a user-defined function? 【发布时间】:2013-01-10 18:08:14 【问题描述】:

我试图弄清楚是否可以在用户定义的函数中插入一列作为参数。

我想要做的是从某个表中插入一列,然后在我调用函数时返回该列的最小值。 (出于我的目的,这不是我想要的实际最小值,我只希望它返回一个数字,无论是最小值、最大值、方差、标准差,还是任何其他给我一个标量值的数学方程)。

【问题讨论】:

你问你能不能SELECT someFunction() 你用的是什么关系型数据库? 您在寻找用户定义的聚合吗? msdn.microsoft.com/en-us/library/ms131057.aspx @RichardDeeming...看起来我可能正在寻找用户定义的聚合...以前从未使用过。我会调查一下,看看我能做些什么。我正在使用 Microsoft SQL Server 2008。 【参考方案1】:

您需要通过sp_executesql 使用动态SQL

CREATE procedure dbo.[myfunc](@COL NVARCHAR(20),
                             @result int output)
AS
BEGIN
DECLARE @SQLString nvarchar(500)
DECLARE @ParmDefinition nvarchar(500)

SET @SQLString = N'SELECT @max_valueOUT = max(' + @COL + ') FROM mytable'
SET @ParmDefinition = N'@max_valueOUT int OUTPUT'

EXECUTE sp_executesql @SQLString, @ParmDefinition, @max_valueOUT=@result OUTPUT
END

SQL Fiddle

【讨论】:

不,我没有。所以,可能有错别字。 对不起,我的意思是运行它(它会编译但不会运行)。 显然,您的数据库中需要有 mytable。调用函数时,您需要传递一个正确的列,该列的类型为 INT 它甚至不会走那么远。 你说得对。您不能从函数中调用存储过程。所以,它一定是一个存储过程【参考方案2】:

我以前做过。您必须创建一个用户定义的数据类型。然后将用户定义的类型传递给函数。

【讨论】:

以上是关于是否可以在用户定义的函数中插入列作为参数?的主要内容,如果未能解决你的问题,请参考以下文章

两个表作为用户定义函数的参数

是否可以将列作为参数传递给 ORDER BY 子句?

是否有人创建了将十进制数作为参数的雪花用户定义函数 (SQL)?

是否有某种方法可以为用户定义的函数调用和存储 Excel 文件? [复制]

Oracle 的用户自定义聚合函数可以定义为与两列一起使用吗?

带有 dplyr 的用户定义函数 - 变异列是一个参数