关于max()/min()和group by 的坑

请编写一个 SQL 查询,描述每一个玩家首次登陆的设备名称

select player_id,device_id,min(event_date) 
from Activity
group by player_id

 

当使用分组语句时,SELECT语句后面只能出现分组字段和聚合函数。 

上面的运行结果是有问题的,player_id和min(event_date)是没有错误的,因为一个用于group by,一个在聚合函数min中,而device_id没有进行任何操作。你会发现数据对不上,第一行的device_id应该是1,而不是2。所以在不涉及player_id和min(event_date)以外的列是没有问题的,如果涉及到,就不要用这种方法了。

max()和min()都只影响()中的这个字段,因此无论是最大值还是最小值,它都是对的,但它不会影响整行数据,


方法一:先用player_id, min(event_date),避免用到第三个字段,然后从原始表提取符合条件的数据

select player_id, device_id,event_date
from activity
where (player_id, event_date) in 
(select player_id, min(event_date)
from activity
group by player_id)

 方法二:不用max,min,改换用排名函数

select player_id, device_id
from (select player_id, device_id, dense_rank() over(partition by player_id order by event_date asc) rk from activity) a
where a.rk=1

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值