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

  • 相关阅读:
    Android:JNI之Java和C层的相互调用及多线程的回调实现
    高通sdm845_la2.0源码编译及使用QFIL刷机
    git常用指令
    Bouml快速使用指南
    Linux内核数据结构之kfifo详解
    输入系统:进程间双向通信(socketpair+binder)
    Android : 跟我学Binder --- (6) JAVA实现
    【LeetCode】167. Two Sum II
    【LeetCode】1. Two Sum
    【LeetCode】206. Reverse Linked List
  • 原文地址:https://www.cnblogs.com/shinggang/p/1999582.html
Copyright © 2011-2022 走看看