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

    --*/

  • 相关阅读:
    Linux下docker安装教程
    基于spark邮件自动分类
    多项式相关算法集成
    基于Bert的文本情感分类
    基于sklearn的分类器实战
    LDA && NCA: 降维与度量学习
    DataStream API介绍和示例
    Apache Flink 简单介绍和入门
    Hbase 表设计和高级属性
    hbase基础shell操作
  • 原文地址:https://www.cnblogs.com/qanholas/p/2556417.html
Copyright © 2011-2022 走看看