0


sql Left Join 关联多条数据情况下只取一条数据

存在b表中foreign_key多条关联a表中的id

select a.name, b.age
from table a
left join table b on a.id =b.foreign_key

需要只取b表中的一条数据(例如取最新的时间的一条)
1.解决方式:使用ROW_NUMBER () over()新增一列编号,排序后对新增列进行筛选

select a.name, b.age,ROW_NUMBER()OVER( PARTITION BY b.id ORDER BY b.last_update_date DESC) AS group_idx
from table a
left join table b on a.id =b.foreign_key
where group_idx =1//新增列进行筛选(关联b表后为空的情况可加上:or group_idx is null)

2.解决方式:使用listagg函数多列转一行,再结合substr函数截取最后一条

select a.name, b.age,
SUBSTR(listagg(b.id,'/') WITHIN GROUP (ORDER BY b.last_update_date DESC),-5) //固定数值数
from table a
left join table b on a.id =b.foreign_key
标签: sql 数据库

本文转载自: https://blog.csdn.net/qq_38864315/article/details/132342739
版权归原作者 离人的梦 所有, 如有侵权,请联系我们删除。

“sql Left Join 关联多条数据情况下只取一条数据”的评论:

还没有评论