bra*_*n k 2 sql t-sql sql-server cursor user-defined-functions
我在本周早些时候在SQL Server 2008中创建了以下函数,该函数接受两个参数并使用它们来选择"详细"记录列,并将它们作为逗号分隔值的单个varchar列表返回.现在我开始思考它,我想采用这个表和特定于应用程序的函数,并使其更通用.
我不是很精通定义SQL函数,因为这是我的第一个.如何更改此功能以接受单个"列"数据,以便我可以更通用的方式使用它?
而不是打电话:
SELECT ejc_concatFormDetails(formuid, categoryName)
Run Code Online (Sandbox Code Playgroud)
我想让它的工作方式如下:
SELECT concatColumnValues(SELECT someColumn FROM SomeTable)
Run Code Online (Sandbox Code Playgroud)
这是我的函数定义:
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
Run Code Online (Sandbox Code Playgroud)
如您所见,我在我的函数中选择列数据,然后使用游标循环结果以构建逗号分隔的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)
Run Code Online (Sandbox Code Playgroud)
诀窍是使用FOR XML PATH('')- 这将返回data列和固定', '分隔符的连接列表.添加一个SUBSTRING(),你就完成了!就像那样简单.....没有顽固的慢CURSOR,没有混乱的连接和所有那些粘糊糊的代码 - 只有一个声明,而这就是全部.