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

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条)

相关推荐 更多相似问题