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 行受影响)

    --*/

  • 相关阅读:
    js学习---常用的内置对象(API)小结 :
    js第四天学习小结:
    学习js第三天小结
    学习js第二天小结
    tomcat+redis会话共享
    linux文件归档脚本
    服务器群秒级别文件同步(ssh+SHELL)
    elasticsearch的索引自动清理及自定义清理
    ELK安装配置
    Logstash自带正则表达式
  • 原文地址:https://www.cnblogs.com/qanholas/p/2556417.html
Copyright © 2011-2022 走看看