煦风V 2022-12-20 09:50 采纳率: 60%
浏览 113
已结题

关于#SQL#的问题,如何解决?

SQL数据去重问题
举例:a b c d 列

根据 bcd列分组后

如果a列中互相包含取长的 如果不包含则还取a

这个sql 能实现吗?

  • 写回答

8条回答 默认 最新

  • gnn_explorer 2022-12-20 11:08
    关注

    SQL 和 实现结果如下:

    select * from test_gnn_merge_stage;
    
    -- 数据准备:
    -- 
    -- a  |b  |c  |d  |
    -- ---+---+---+---+
    -- abc|xxx|xxx|xxx|
    -- ab |xxx|xxx|xxx|
    -- a  |xxx|xxx|xxx|
    -- abc|yyy|yyy|yyy|
    -- bce|yyy|yyy|yyy|
    -- abc|zzz|zzz|zzz|
    -- bce|zzz|zzz|zzz|
    -- ce |zzz|zzz|zzz|
    
    select 
      t2.*
    from(
        select 
            b,
            c,
            d,
            GROUP_CONCAT(CONCAT('_',a, '_')) as a_all
        from test_gnn_merge_stage
        group by b,c,d
    ) t1 
    join test_gnn_merge_stage t2 on t1.b = t2.b and t1.c = t2.c and t1.d = t2.d
    
    where replace(t1.a_all, CONCAT('_',t2.a, '_'), '') not like CONCAT('%', t2.a, '%') 
    
    -- 运行结果:
    -- a  |b  |c  |d  |
    -- ---+---+---+---+
    -- abc|xxx|xxx|xxx|
    -- abc|yyy|yyy|yyy|
    -- bce|yyy|yyy|yyy|
    -- abc|zzz|zzz|zzz|
    -- bce|zzz|zzz|zzz|
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(7条)

报告相同问题?

问题事件

  • 系统已结题 12月28日
  • 已采纳回答 12月20日
  • 赞助了问题酬金20元 12月20日
  • 创建了问题 12月20日

悬赏问题

  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?
  • ¥15 QTOF MSE数据分析
  • ¥15 平板录音机录音问题解决