久久九六 2019-03-22 10:20 采纳率: 100%
浏览 621
已采纳

SqlSever数据库实现分组查询

表名:PrescriptionSystemClass
表结构:有两个字段,classId和typeId
查询出来数据:
classId  typeId
 1    1
 1    4
 1    6
 2    3
 2    1
 3    5
 3    10
 3    8

如何实现按照classId分组查询,让typeId显示成为一行,中间用符号分开?
效果如下:
classId  typeId
 1    1,4,6
 2    1,3
 3    5,8,10

  • 写回答

2条回答 默认 最新

  • l_w610 2019-03-22 10:51
    关注
    
    SELECT  classId ,
            STUFF(( SELECT  ',' + CONVERT(VARCHAR(20), typeId)
                    FROM    PrescriptionSystemClass
                    WHERE   classId = t.classId
                  FOR
                    XML PATH('')
                  ), 1, 1, '')
    FROM    PrescriptionSystemClass t
    GROUP BY classId
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 依据报错在原代吗格式的基础上解决问题
  • ¥15 在虚拟机中安装flash code
  • ¥15 单片机stm32f10x编写光敏电阻调节3.3伏大功率灯亮度(光强越大灯越暗,白天正常光强灯不亮,使用ADC,PWM等模块)望各位找一下错误或者提供一个可实现功能的代码
  • ¥20 verilog状态机方法流水灯
  • ¥15 pandas代码实现不了意图
  • ¥15 GD32H7 从存储器到外设SPI传输数据无法重复启用DMA
  • ¥25 LT码在高斯信道下的误码率仿真
  • ¥45 渲染完成之后将物体的材质贴图改变,自动化进行这个操作
  • ¥15 yolov5目标检测并显示目标出现的时间或视频帧
  • ¥15 电视版的优酷可以设置电影连续播放吗?