煦风V 2022-12-20 09:50 采纳率: 75%
浏览 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 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)