shaokel 2021-07-19 15:44 采纳率: 95.2%
浏览 23
已采纳

oracle DISTINCT提示需要group by

单纯DISTINCT一个字段有没有出现这样的问题。还是我语法用错了

img

  • 写回答

1条回答 默认 最新

  • 咕泡-景天 2021-07-19 16:09
    关注

    你这个语法有问题啊,你使用的distinct是对后面所有的字段进行去重,我这里跟你提供一种方式,你可以尝试一下

    先去重,再聚合
    select t.department_name depname,
    t.department_key,
    listagg(t.class_key, ',') within group(order by t.class_key) as class_keys
    from (select distinct s.class_key, s.department_key, s.department_name
    from V_YDXG_TEACHER_KNSRDGL s) t
    group by t.department_key, t.department_name

    --或者
    select s.department_key,
    s.department_name,
    listagg(s.class_key, ',') within group(order by s.class_key) as class_keys
    from (select t.department_key,
    t.department_name,
    t.class_key,
    row_number() over(partition by t.department_key, t.department_name, t.class_key order by t.department_key, t.department_name) as rn
    from V_YDXG_TEACHER_KNSRDGL t
    order by t.department_key, t.department_name, t.class_key) s
    where rn = 1
    group by s.department_key, s.department_name;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 7月19日
  • 创建了问题 7月19日

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料