首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何在SQL Server中创建接受一列数据的函数?

如何在SQL Server中创建接受一列数据的函数?
EN

Stack Overflow用户
提问于 2010-05-07 13:22:08
回答 4查看 6.7K关注 0票数 2

本周早些时候,我在SQL Server2008中实现了以下函数,该函数接受两个参数,并使用它们来选择一列“详细”记录,并将它们作为逗号分隔值的单个varchar列表返回。考虑到这一点,我想采用这个特定于表和应用程序的函数,并使其更加通用。

我并不精通SQL函数的定义,因为这是我的第一次。如何将此函数更改为接受单个“列”值的数据,以便能够以更通用的方式使用它?

而不是调用:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT ejc_concatFormDetails(formuid, categoryName)

我想让它像这样工作:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT concatColumnValues(SELECT someColumn FROM SomeTable)

下面是我的函数定义:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
FUNCTION [DNet].[ejc_concatFormDetails](@formuid AS int, @category as VARCHAR(75))
RETURNS VARCHAR(1000) AS
BEGIN
 DECLARE @returnData VARCHAR(1000)
 DECLARE @currentData VARCHAR(75)
 DECLARE dataCursor CURSOR FAST_FORWARD FOR
  SELECT data FROM DNet.ejc_FormDetails WHERE formuid = @formuid AND category = @category

 SET @returnData = ''

 OPEN dataCursor

 FETCH NEXT FROM dataCursor INTO @currentData
 WHILE (@@FETCH_STATUS = 0)
 BEGIN
  SET @returnData = @returnData + ', ' + @currentData
  FETCH NEXT FROM dataCursor INTO @currentData
 END

 CLOSE dataCursor
 DEALLOCATE dataCursor

 RETURN SUBSTRING(@returnData,3,1000)
END

正如您所看到的,我选择了函数中的列数据,然后使用光标循环遍历结果,以构建逗号分隔的varchar。

如何将其更改为接受作为结果集的单个参数,然后使用游标访问该结果集?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-05-07 13:26:17

您可以使用表值参数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE FUNCTION MyFunction(
    @Data AS TABLE (
        Column1 int,
        Column2 nvarchar(50),
        Column3 datetime
    )
)
RETURNS NVARCHAR(MAX)
AS BEGIN
    /* here you can do what you want */
END
票数 2
EN

Stack Overflow用户

发布于 2010-05-07 13:35:19

其他人已经回答了你的主要问题--但让我指出你的函数的另一个问题--游标的可怕使用!

你可以很容易的重写这个函数,让它不使用游标,不使用循环--完全不是这样。它将会更快,更简单,更少的代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
FUNCTION DNet.ejc_concatFormDetails
            (@formuid AS int, @category as VARCHAR(75))
RETURNS VARCHAR(1000) 
AS
    RETURN 
      SUBSTRING(
        (SELECT ', ' + data
         FROM DNet.ejc_FormDetails 
         WHERE formuid = @formuid AND category = @category
         FOR XML PATH('')
        ), 3, 1000)

诀窍是使用FOR XML PATH('') -它返回data列和固定的', '分隔符的连接列表。在上面添加一个SUBSTRING(),你就完成了!就这么简单……没有慢吞吞的CURSOR,没有混乱的连接和所有的粘性代码--只有一条语句,这就是全部。

票数 5
EN

Stack Overflow用户

发布于 2010-05-07 13:28:19

您可以从SQL Server2008开始使用Table Valued Parameters,这将允许您将表变量作为参数传入。这方面的限制和示例都在该链接的文章中。

但是,我也要指出,使用游标很可能会对性能造成影响。您不需要使用游标,因为您可以在一条SELECT语句中完成所有操作:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT @MyCSVString = COALESCE(@MyCSVString + ', ', '') + data 
FROM DNet.ejc_FormDetails 
WHERE formuid = @formuid AND category = @category

不需要游标

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2788820

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文