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
文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。