How to split a comma-separated value to columns

后端 未结 30 4039
刺人心
刺人心 2020-11-21 04:38

I have a table like this

Value   String
-------------------
1       Cleo, Smith

I want to separate the comma delimited string into two colu

30条回答
  •  情歌与酒
    2020-11-21 05:10

    CREATE FUNCTION [dbo].[fn_split_string_to_column] (
        @string NVARCHAR(MAX),
        @delimiter CHAR(1)
        )
    RETURNS @out_put TABLE (
        [column_id] INT IDENTITY(1, 1) NOT NULL,
        [value] NVARCHAR(MAX)
        )
    AS
    BEGIN
        DECLARE @value NVARCHAR(MAX),
            @pos INT = 0,
            @len INT = 0
    
        SET @string = CASE 
                WHEN RIGHT(@string, 1) != @delimiter
                    THEN @string + @delimiter
                ELSE @string
                END
    
        WHILE CHARINDEX(@delimiter, @string, @pos + 1) > 0
        BEGIN
            SET @len = CHARINDEX(@delimiter, @string, @pos + 1) - @pos
            SET @value = SUBSTRING(@string, @pos, @len)
    
            INSERT INTO @out_put ([value])
            SELECT LTRIM(RTRIM(@value)) AS [column]
    
            SET @pos = CHARINDEX(@delimiter, @string, @pos + @len) + 1
        END
    
        RETURN
    END
    

提交回复
热议问题