world_wood 2022-03-15 09:44 采纳率: 100%
浏览 42
已结题

sql题:如何获取分组后,里面的某些指定行的数据。

img

第三题如何解答?
我只能写下如下语句,但是没有的得到ID,花名,因为这两个字段聚合下可能存在多个值,百度说用any_value(),但是不是最大花瓣数的ID,花名。

img

  • 写回答

3条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-15 13:25
    关注

    如果是mysql 8.0以上,可以用开窗函数row_number进行分组排序

    select fid,name,angs,color,ct from (
    select f.*,ifnull(s.angs,0) angs,
    row_number() over (partition by color order by ifnull(s.angs,0) desc) rn,
    count(1) over (partition by color ) ct
    from flower f left join shape s on f.fid=s.fid)
    where rn=1
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月23日
  • 已采纳回答 3月15日
  • 创建了问题 3月15日