【SQL】1407. 排名靠前的旅行者

题目描述

leetcode题目:1407. 排名靠前的旅行者



Code

写法一

先过滤,再连表

sql 复制代码
-- 写法一:先过滤再连表
select name, ifnull(summ, 0) as travelled_distance
from Users
left join(
    select user_id, sum(distance) as summ
    from Rides
    group by user_id
) A
on Users.id = A.user_id
order by summ desc, name asc;

写法二

先连表,再过滤

sql 复制代码
-- 写法二:先连表再过滤
select  name, ifnull(sum(distance), 0) as travelled_distance
from Users U 
left join Rides R
on U.id = R.user_id
group by R.user_id
order by travelled_distance desc, name;
相关推荐
veminhe1 小时前
Node.js 数据库 CRUD 项目示例
数据库·node.js
HX科技1 小时前
树莓派_利用Ubuntu搭建gitlab
数据库·ubuntu·gitlab
pursue.dreams1 小时前
Windows 下 MongoDB ZIP 版本安装指南
数据库·windows·mongodb
煤烦恼2 小时前
Spark-SQL核心编程(二)
大数据·sql·spark
qiandeqiande2 小时前
数据集成工具推荐,支持数据库、API、消息文件等集成技术,并具备低代码与可视化配置特性
数据库·低代码·系统集成
betazhou2 小时前
基于Windows通过nginx代理访问Oracle数据库
数据库·nginx·oracle·代理
风中飘爻2 小时前
MySQL入门:数据表的创建
数据库·mysql·oracle
今天多喝热水2 小时前
Redis适用场景
数据库·redis
Gauss松鼠会3 小时前
GaussDB Go驱动开发实战:从环境搭建到连接池优化
数据库
E___V___E3 小时前
黑马点评redis改 part 2
数据库·redis·缓存