小编bra*_*n k的帖子

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

我在本周早些时候在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 …
Run Code Online (Sandbox Code Playgroud)

sql t-sql sql-server cursor user-defined-functions

2
推荐指数
1
解决办法
6135
查看次数

标签 统计

cursor ×1

sql ×1

sql-server ×1

t-sql ×1

user-defined-functions ×1