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

标签 sql sql-server tsql cursor user-defined-functions

本周早些时候,我在 SQL Server 2008 中创建了以下函数,该函数采用两个参数并使用它们来选择“详细”记录列,并将它们作为逗号分隔值的单个 varchar 列表返回。既然我开始考虑它,我想采用此表和特定于应用程序的函数并使其更通用。

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

而不是调用:

SELECT ejc_concatFormDetails(formuid, categoryName)

我想让它像这样工作:

SELECT concatColumnValues(SELECT someColumn FROM SomeTable)

这是我的函数定义:

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。

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

最佳答案

其他人已经回答了您的主要问题 - 但让我指出您的函数的另一个问题 - CURSOR 的糟糕使用!

您可以轻松地重写此函数,使其不使用游标、不使用 WHILE 循环——完全不像那样。它会更快,也更容易 - 更少的代码:

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,没有乱七八糟的连接和所有那些粘糊糊的代码 - 只有一个语句,就是这样。

关于sql - 如何在 SQL Server 中创建接受一列数据的函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2788820/

相关文章:

sql - 选择5个最新的SQL Server

sql-server - TSQL 'Invalid column name' sproc 参数值错误

给出匹配多列的不同结果的 SQL 查询

sql - Unix shell 脚本并行运行 SQL 脚本

sql-server - 如何在 SQL Server 中的特定字符后分割字符串并将该值更新到特定列

sql - 同一张表上 SQL 中的关系

SQL服务器: need to escape [?

mysql - 如何在mysql中将多行合并为一行

sql - 如何优化我的sql查询

SQL Server : Extract Table Meta-Data (description, 字段及其数据类型)