关于max()/min()和group by 的坑
程序员文章站
2022-04-20 21:47:05
...
请编写一个 SQL 查询,描述每一个玩家首次登陆的设备名称
select player_id,device_id,min(event_date)
from Activity
group by player_id
上面的运行结果是有问题的,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
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