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

打印 上一主题 下一主题

主题 1019|帖子 1019|积分 3061

存在b表中foreign_key多条关联a表中的id
  1. select a.name, b.age
  2. from table a
  3. left join table b on a.id =b.foreign_key
复制代码
必要只取b表中的一条数据(例如取最新的时间的一条)
1.办理方式:使用ROW_NUMBER () over()新增一列编号,排序后对新增列进行筛选
  1. select a.name, b.age,
  2. ROW_NUMBER () OVER ( PARTITION BY b.id ORDER BY b.last_update_date DESC) AS group_idx
  3. from table a
  4. left join table b on a.id =b.foreign_key
  5. where group_idx = 1 //新增列进行筛选(关联b表后为空的情况可加上:or group_idx is null)
复制代码
2.办理方式:使用listagg函数多列转一行,再结合substr函数截取最后一条
  1. select a.name, b.age,
  2. SUBSTR(listagg(b.id,'/') WITHIN GROUP (ORDER BY b.last_update_date DESC),-5) //固定数值数
  3. from table a
  4. left join table b on a.id =b.foreign_key
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

东湖之滨

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表