zoukankan      html  css  js  c++  java
  • SQL查询合并字符串

    a表
    a列 b列
    1   a
    1   b
    1   c
    2   a
    2   b
    能否不用存储过程 直接sql  得到
    1 a,b,c
    2 a,b,c
    这样的结果

    可以的,用交叉方法
    select a列,
    max(case when b列='a' then 'a' else '' end) 列1,
    max(case when b列='b' then 'b' else '' end) 列2,
    max(case when b列='c' then 'c' else '' end) 列3
    into temp_1219--插入临时表
    from a表
    group by a列
    这个是静态的行列转换,
    如果是动态的行列装换,也就是说你不知道表中a列的行数有很多,需要写过程对sql语句进行拼接

    然后根据你的需要再对字段进行合并
    select a列,列1+','+列2+','+列3 b列
    into temp_1219_result--插入结果表
    from temp_1219


    /*--优化
    update temp_1219
    set 列2=','+列2
    where len(列2)>0
    update temp_1219
    set 列3=','+列3
    where len(列3)>0

    select a列,列1+列2+列3 b列
    into temp_1219_result2--插入结果表
    from temp_1219
    */

    案例2:

    测试数据
    编号   物料类别    产品编号
    1       铅笔        0001
    2       铅笔        0002
    3       铅笔        0001
    4       钢笔        0004
    5       钢笔        0005
    6       钢笔        0004
    7       圆珠笔      0007
    8       圆珠笔      0008
    9       圆珠笔      0007

    等等

    要求实现以下效果:
    编号    物料类别   产品编号
    1       铅笔       0001,0002
    2       钢笔       0004,0005
    3       圆珠笔     0007,0008

    **我的目的是如果不重复则合并产品编号,如果重复则舍弃**

    create table T(编号 int, 物料类别 nvarchar(10), 产品编号 char(5))
    insert T select 1,       '铅笔',        '0001'
    union all select 2,       '铅笔',        '0002'
    union all select 3,       '铅笔',        '0001'
    union all select 4,       '钢笔',        '0004'
    union all select 5,       '钢笔',        '0005'
    union all select 6,       '钢笔',        '0004'
    union all select 7,       '圆珠笔',    '0007'
    union all select 8,       '圆珠笔',      '0008'
    union all select 9,       '圆珠笔',      '0007'

    create function fun(@物料类别 nvarchar(10))
    returns nvarchar(200)
    as
    begin
        declare @re nvarchar(200)
        set @re=''
        select @re=@re+产品编号+',' from T where 物料类别=@物料类别 group by 产品编号

        select @re=left(@re, len(@re)-1)
        return @re
    end

    select distinct 物料类别, dbo.fun(物料类别) from T

    --result
    物料类别                                   
    ---------- -------------------------------
    钢笔         0004 ,0005
    铅笔         0001 ,0002
    圆珠笔        0007 ,0008

    (3 row(s) affected)


    后記:
    核心語句中最后面的group by XXX 可舍棄重復。
    select @re=@re+产品编号+',' from T where 物料类别=@物料类别 group by 产品编号

    又一篇笔记,以备后用!!

    需求:

    有表tb,表有两个字段,分别为:id,value。

    表中存有数据如下:id        value

                             1         a

                             1         a1

                             1         a2

                             2         b

                             2         b1

                             3         c1

                             3         c2

    需要通过查询实现:1         a,a1,a2

                                  2         b,b1

                                  3         c1,c2

    实现方法:

              1、sql2000 使用合并函数:

              create function f_tb(@id int)
    returns varchar(8000)
    as
    begin
      declare @str varchar(8000)
      set @str = ''
      select @str = @str + ',' + cast(value as varchar) from tb where id = @id
      set @str = right(@str , len(@str) - 1)
      return(@str)
    End
    go

    --调用自定义函数得到结果:
    select distinct id ,dbo.f_tb(id) as value from t


              2、sql2005 处理方式如下:

    SELECT * FROM(SELECT DISTINCT id FROM tb)A OUTER APPLY(
            SELECT [values]= STUFF(REPLACE(REPLACE(
                (
                    SELECT value FROM tb N
                    WHERE id = A.id
                    FOR XML AUTO
                ), '<N value="', ','), '"/>', ''), 1, 1, '')
    )N

  • 相关阅读:
    JavaScript定时器及相关面试题
    单线程JavaScript
    webpack基础入门
    SQL Server 服务器器信息备份(二)--权限备份
    SQL Server 服务器器信息备份(一)--login新建脚本备份
    Raid与DAN、SAN、NAS基础
    AlwaysOn可用性组功能测试(三)--其他测试
    AlwaysOn可用性组功能测试(二)--SQL Server群集故障转移对AlwaysOn可用性组的影响
    AlwaysOn可用性组功能测试(一)--AlwaysOn故障转移测试
    AlwaysOn可用性组测试环境安装与配置(一)--SQL群集环境搭建
  • 原文地址:https://www.cnblogs.com/shinggang/p/1999582.html
Copyright © 2011-2022 走看看