Every day a leetcode

题目来源: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 。

写一段 SQL , 报告每个用户的旅行距离。

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

查询结果格式如下例所示。

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      |
+------+----------+----------+Result 表:
+----------+--------------------+
| 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。

SQL代码

# Write your MySQL query statement below
SELECT name, SUM(distance) AS travelled_distance
FROM Users LEFT JOIN Rides
ON Users.id=Rides.user_id
GROUP BY name
ORDER BY travelled_distance DESC, name ASC;

结果

分析

比较输出和预期结果,我们发现:

我们要将 NULL 改成 0,则要用到 IFNULL 函数或者 COALESCE函数。

代码:IFNULL(SUM(distance), 0)

# Write your MySQL query statement below
SELECT name, IFNULL(SUM(distance), 0) AS travelled_distance
FROM Users LEFT JOIN Rides
ON Users.id=Rides.user_id
GROUP BY name
ORDER BY travelled_distance DESC, name ASC;

结果:

代码:IFNULL(SUM(distance), 0)

# Write your MySQL query statement below
SELECT name, COALESCE(SUM(distance), 0) AS travelled_distance
FROM Users LEFT JOIN Rides
ON Users.id=Rides.user_id
GROUP BY name
ORDER BY travelled_distance DESC, name ASC;

结果:

Leetcode1407. 排名靠前的旅行者相关推荐

  1. 1407. 排名靠前的旅行者

    SQL架构 表:Users +---------------+---------+ | Column Name | Type | +---------------+---------+ | id | ...

  2. 1407 排名靠前的旅行者

    写一段 SQL , 报告每个用户的旅行距离. 返回的结果表单,以 travelled_distance 降序排列 ,如果有两个或者更多的用户旅行了相同的距离, 那么再以 name 升序排列 . 查询结 ...

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

    leetcode-SQL-1407. 排名靠前的旅行者 题目 解题 题目 题目链接 表:Users +---------------+---------+ | Column Name | Type | ...

  4. Leecode-SQL 1407. 排名靠前的旅行者

    错误解法 select u.name,sum(r.distance) travelled_distance from Users u,Rides r where r.user_id=u.id grou ...

  5. 怎么写显示商品图片_shopee商品描述怎么写,shopee商品排名靠前的是

    我做跨境电商也有六年的时间了,在电商这个行业也有自己的一些经验.经验也许没有其他大卖家丰富,但会将我知道的都进行分享.如果有不懂得亚马逊问题可以+我(V:543482465).我这里给大家安排一堂直播 ...

  6. 安徽阜阳计算机高中学校排名,安徽阜阳排名靠前的三大高中,有争议?2020年高考成绩说话!...

    安徽省阜阳市,古称汝阴,阜阳历史悠久.文化璀璨.人才辈出,有阜阳剪纸等国家非物质文化遗产,也是管仲.鲍叔牙等历史名人的故乡:阜阳风景秀丽,辖区内有诸多知名景点,其中八里河风景区为国家AAAAA级风景区 ...

  7. SEO|搜索引擎优化(如何让你的网站排名靠前)

    如何让你的网站排名靠前         网站做好了,怎样才能让你的网站在各大搜索引擎中排名靠前呢?网上的帖子很多,通过搜索和总结,整理出了一套自己行之有效的方法,写出来供大家参考 成功案例推荐:天气预 ...

  8. 计算机名称 steam,Steam电脑配置排名:前19名都是N卡

    原标题:Steam电脑配置排名:前19名都是N卡 现如今的显卡市场上,NVIDIA无疑占据着绝对主动和领导地位,那么N卡到底普及到了什么程度? Steam今天更新了每月一次的硬件调查结果,虽然数据都来 ...

  9. 哪几所大学计算机软件方面是强项,计算机软件工程专业排名靠前的大学是那几所...

    导读:本文是来自mlh的网友投稿,由编辑发布关于计算机软件工程专业排名靠前的大学是那几所的内容介绍 计算机应用领域的不断扩大及我国经济大力开展,软件工程专业已经成为一个最新的抢手专业,不仅因为工作好找 ...

最新文章

  1. 2021-2027年中国中高端女装行业市场分析预测及投资方向研究报告
  2. .NET应用三层架构分析
  3. nodejs 开发企业微信第三方应用入门教程
  4. 互联网工作原理(17.网络电视是如何工作的)
  5. 求职特训营火热来袭 阿里大咖教你制作专业简历
  6. linux 命令 find -exec 操作的问题
  7. .Net读取rss的两种方法
  8. 大数据分析的价值体现
  9. java day57【 Spring 概述 、 IoC 的概念和作用、使用 spring 的 IOC 解决程序耦合 】...
  10. Cplex20.1版本bin包Linux安装过程
  11. 历年研究生数学建模赛题题目
  12. 电影院购票系统ssm (含论文)
  13. JDK7~13的新特性
  14. 北航机械学院计算机制图,北航机械制图在线作业一含答案.pdf
  15. 不同尺寸证件照混合打印
  16. bash: yum:未找到命令
  17. LSD(线段检测测试文件)
  18. Excel如何快速批量生成指定性别的随机姓名
  19. 知识点六:jQuery遍历-同胞Siblings(), next(), nextAll()
  20. ESP32学习笔记(22)——ADC接口使用

热门文章

  1. java互联网医院源码 智慧医院源码 图文问诊系统源码
  2. 统计单词频率 java_java 统计一个(英文)文本中频率最高的10个单词
  3. abb机器人过载报错_ABB机器人常见报警代码与解决方案
  4. python彩蛋_隐藏在Python中的15个彩蛋
  5. dz论坛php5,S!淘专辑 3.0.1 For php5.2 php5.3版 dz插件分享,淘专辑是用户将喜欢的论坛帖子...
  6. 证券公司信息化2-投资银行业务是做什么的,怎样赚钱,IT在里边起到什么作用?
  7. 2023年中央财经大学数量经济学考博必看上岸前辈复习经验分享
  8. TP全行业小程序运营管理系统源码+一键生成小程序
  9. 英美团队发现神秘信号:金星上可能存在生命?
  10. 手机app和单片机蓝牙通讯c语言,单片机怎么和手机通信,你知道吗?