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

  • 相关阅读:
    ZYNQ xilinx之困惑
    位操作的宏函数实现
    BCG信号的检测【时时更新】
    课题兼申请任务Freescale的K60系列
    SDRAM之持续中。。。。。。
    几款常见的免费网站程序
    常用运放选型
    SDRAM之开始burst length
    谈 数学之美 和 看见
    C语言中的可变参数(...)
  • 原文地址:https://www.cnblogs.com/shinggang/p/1999582.html
Copyright © 2011-2022 走看看