加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

将行合并到一个CSV文件(a.k.a SQL Server的GROUP_CONCAT)

发布时间:2020-12-12 08:52:12 所属栏目:MsSql教程 来源:网络整理
导读:我有一张桌子: EntityID AttributeID OptionText5016 20 Paintings5044 18 Female5060 48 M5060 48 F5060 49 Apple5060 49 Banana5060 49 Cat 我想创建一个将显示的视图: 5016 20 Paintings5044 18 Female5060 48 M,F5060 49 Apple,Banana,Cat 均值每个实体
我有一张桌子:
EntityID   AttributeID  OptionText
5016       20           Paintings
5044       18           Female
5060       48           M
5060       48           F
5060       49           Apple
5060       49           Banana
5060       49           Cat

我想创建一个将显示的视图:

5016    20   Paintings
5044    18   Female
5060    48   M,F
5060    49   Apple,Banana,Cat

均值每个实体上的属性值应以逗号分隔.

选项的数量可以变化.

任何帮助是赞赏!

解决方法

对于EntityID的每一对,AttributeID使用XML路径技巧生成CSV
SELECT
    M.EntityID,M.AttributeID,SUBSTRING(CAST(foo.bar AS varchar(8000)),2,7999) AS Options
FROM
    (
    SELECT DISTINCT EntityID,AttributeID
    FROM MyTable
    ) M
    CROSS APPLY
    (
    SELECT
        ',' + OptionText
    FROM
        MyTable M2
    WHERE
        M.EntityID = M2.EntityID AND M.AttributeID= M2.AttributeID
    FOR XML PATH ('')
    ) foo(bar)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读