SQL-leetcode—1407. 排名靠前的旅行者

1407. 排名靠前的旅行者

表:Users

±--------------±--------+

| Column Name | Type |

±--------------±--------+

| id | int |

| name | varchar |

±--------------±--------+

id 是该表中具有唯一值的列。

name 是用户名字。

表:Rides

±--------------±--------+

| Column Name | Type |

±--------------±--------+

| id | int |

| user_id | int |

| distance | int |

±--------------±--------+

id 是该表中具有唯一值的列。

user_id 是本次行程的用户的 id, 而该用户此次行程距离为 distance 。

编写解决方案,报告每个用户的旅行距离。

返回的结果表单,以 travelled_distance 降序排列 ,如果有两个或者更多的用户旅行了相同的距离, 那么再以 name 升序排列 。

返回结果格式如下例所示。

示例 1:

输入:

Users 表:

±-----±----------+

| id | name |

±-----±----------+

| 1 | Alice |

| 2 | Bob |

| 3 | Alex |

| 4 | Donald |

| 7 | Lee |

| 13 | Jonathan |

| 19 | Elvis |

±-----±----------+

Rides 表:

±-----±---------±---------+

| id | user_id | distance |

±-----±---------±---------+

| 1 | 1 | 120 |

| 2 | 2 | 317 |

| 3 | 3 | 222 |

| 4 | 7 | 100 |

| 5 | 13 | 312 |

| 6 | 19 | 50 |

| 7 | 7 | 120 |

| 8 | 19 | 400 |

| 9 | 7 | 230 |

±-----±---------±---------+

输出:

±---------±-------------------+

| name | travelled_distance |

±---------±-------------------+

| Elvis | 450 |

| Lee | 450 |

| Bob | 317 |

| Jonathan | 312 |

| Alex | 222 |

| Alice | 120 |

| Donald | 0 |

±---------±-------------------+

解释:

Elvis 和 Lee 旅行了 450 英里,Elvis 是排名靠前的旅行者,因为他的名字在字母表上的排序比 Lee 更小。

Bob, Jonathan, Alex 和 Alice 只有一次行程,我们只按此次行程的全部距离对他们排序。

Donald 没有任何行程, 他的旅行距离为 0。

题解

报告每个用户的旅行距离。

  • 说明需要把用户作为主表,关联明细表,得到的结果才是每个用户的。
  • 考虑到关联不上为null的距离,需要使用ifnull函数做转换
  • KEY:考虑到重名问题,group by 需要使用id

方法一 join + sum(ifnull(xx)) + 需考虑重名

复制代码
select 
    u1.name as name
    ,sum(ifnull(r1.distance,0)) as travelled_distance
from Users u1 left join Rides r1 on u1.id = r1.user_id
group by u1.id
order by travelled_distance desc,u1.name asc

比较简单不在赘述

提醒一点:也是一开始我在编写sql没有考虑到的情况
group by u1.id 不等于 group by u1.name
当name出现重复的时候

相关推荐
YOU OU2 分钟前
Spring IoC&DI
java·数据库·spring
Muscleheng1 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿2 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
m0_629494732 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
jran-2 小时前
Redis 命令
数据库·redis·缓存
小江的记录本2 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`3 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
二宝哥3 小时前
离线安装maven
java·数据库·maven
SZLSDH3 小时前
场景适配论 | 数字孪生IOC建设中渲染技术与智能体能力的协同逻辑
前端·数据库·ai·数字孪生·数据可视化·智能体
这个DBA有点耶3 小时前
SQL改写实战:子查询、CTE、窗口函数性能对比
数据库·mysql·性能优化