zoukankan      html  css  js  c++  java
  • 分拆列值

    问题描述:

    有表tb, 如下:

    id           values

    ----------- -----------

    1            aa,bb

    2           aaa,bbb,ccc

    欲按,分拆values列, 分拆后结果如下:

    id           value

    ----------- --------

    1            aa

    1            bb

    2            aaa

    2            bbb

    2            ccc

    1. 旧的解决方法

    SELECT TOP 8000

         id = IDENTITY(int, 1, 1)

    INTO #

    FROM syscolumns a, syscolumns b

    SELECT

         A.id,

         SUBSTRING(A.[values], B.id, CHARINDEX(',', A.[values] + ',', B.id) - B.id)

    FROM tb A, # B

    WHERE SUBSTRING(',' + A.[values], B.id, 1) = ','

    DROP TABLE #

    -- 2. 新的解决方法

    -- 示例数据

    DECLARE @t TABLE(id int, [values] varchar(100))

    INSERT @t SELECT 1, 'aa,bb'

    UNION ALL SELECT 2, 'aaa,bbb,ccc'

    -- 查询处理

    SELECT

         A.id, B.value

    FROM(

         SELECT id, [values] = CONVERT(xml,

                 '<root><v>' + REPLACE([values], ',', '</v><v>') + '</v></root>')

         FROM @t

    )A

    OUTER APPLY(

         SELECT value = N.v.value('.', 'varchar(100)')

         FROM A.[values].nodes('/root/v') N(v)

    )B

    /*--结果

    id           value

    ----------- --------

    1            aa

    1            bb

    2            aaa

    2            bbb

    2            ccc

    (5 行受影响)

    --*/

  • 相关阅读:
    最小路径和
    S2 深入.NET和C#编程 机试测试错题积累
    S2 深入.NET和C#编程 笔试测试错题积累
    影院项目的内容信息
    抽象类和抽象的方法注意事项
    六种设计原则
    体检套餐的笔记
    C#图解 类和继承
    深入类的方法
    S2 深入.NET和C#编程 三:使用集合组织相关数据
  • 原文地址:https://www.cnblogs.com/qanholas/p/2556417.html
Copyright © 2011-2022 走看看