• SQL SERVER将指定表中的指定字段按照(,)逗号分隔


    不开心呀,早知道不跳了,一跳跳坑里来了。

    使用方式:

    DECLARE @ConsigneeAddressId INT;
    SET @ConsigneeAddressId = 1;
    SELECT  *
    FROM    ConsigneeAddress A OUTER  APPLY  StrSplit(A.ConsigneeAddress)
    WHERE   ConsigneeAddressId = @ConsigneeAddressId;

     关于   OUTER APPLY和CROSS APPLY的使用   其涉及到的参数 是  当前关联表中的字段

    分割用的自定义函数:

    CREATE FUNCTION StrSplit ( @str VARCHAR(100) )
    RETURNS @tableName TABLE ( str2table VARCHAR(50) )
    AS
        BEGIN
            SET @str = @str + ','
            DECLARE @insertStr VARCHAR(50) --截取后的第一个字符串
            DECLARE @newstr VARCHAR(1000) --截取第一个字符串后剩余的字符串
            SET @insertStr = LEFT(@str, CHARINDEX(',', @str) - 1)
            SET @newstr = STUFF(@str, 1, CHARINDEX(',', @str), '')
            INSERT  @tableName
            VALUES  ( @insertStr )
            WHILE ( LEN(@newstr) > 0 )
                BEGIN
                    SET @insertStr = LEFT(@newstr, CHARINDEX(',', @newstr) - 1)
                    INSERT  @tableName
                    VALUES  ( @insertStr )
                    SET @newstr = STUFF(@newstr, 1, CHARINDEX(',', @newstr), '')
                END
            RETURN
        END

    需要分割分的字段的数据格式:

    以及文章开头sql的执行后的结果:

  • 相关阅读:
    2019-2020-1学期20192401《网络空间安全专业导论》第一周学习总结
    14201771010119穷吉
    13201771010119穷吉
    12穷吉201771010119
    11201771010119穷吉
    实验10穷吉201771010119
    实验九201771010119穷吉
    201771010119穷吉第八周
    七次201771010119穷吉
    实验六20177101010119穷吉
  • 原文地址:https://www.cnblogs.com/Tmc-Blog/p/5126666.html
Copyright © 2020-2023  润新知