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