0

我正在尝试通过引用此处的代码来构建一个接受多值参数的函数。但是,我在创建它时遇到错误。这里有什么问题?

CREATE FUNCTION [dbo].[func_CommaDelimitedString] (@val nvarchar(100))
RETURNS @clublist TABLE (clubname nvarchar(55))
BEGIN
    DECLARE @x int = 1
    DECLARE @y int = CHARINDEX(',', @val)
                    
    WHILE @x < LEN(@val) + 1
    BEGIN
        IF @y = 0
            BEGIN
                SET @y = LEN(@val) + 1
            END
        INSERT INTO @clublist (clubname) VALUES (SUBSTRING(@val, @x, @y - @x))
        SET @x = @y + 1
        SET @y = CHARINDEX(',', @val, @x)
    END
    RETURN
END

消息 103010,级别 16,状态 1,第 1 行解析错误,第 13 行,第 15 列:“@clublist”附近的语法不正确。

我的环境:Microsoft Azure SQL 数据仓库 - 10.0.10887.0 Jan 23 2020 07:36:54 版权所有 (c) Microsoft Corporation

4

1 回答 1

2

Azure Synapse Analytics SQL 池(又名 Azure SQL DW)不支持用户定义的表值函数,仅支持用户定义的标量值函数。请参阅CREATE FUNCTION(SQL 数据仓库)

但它确实支持string_split,所以你不应该需要这个特定的功能。

于 2020-02-12T22:39:22.470 回答