zoukankan      html  css  js  c++  java
  • 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的执行后的结果:

  • 相关阅读:
    themes、skins
    使用GreyBox实现Ajax模式窗口
    .net最小化到系统托盘
    asp.net自定义控件
    [转]SQL函数的简短说明
    prototype1.4 和1.5
    [转]Oracle PL/SQL 编程手册(SQL大全)
    更新同一张表中的数据的方法
    js中eval()的作用
    asp.net中的中文和特殊字符的处理方式!
  • 原文地址:https://www.cnblogs.com/Tmc-Blog/p/5126666.html
Copyright © 2011-2022 走看看