前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【leetcode两题选手】MySQL类题目(一)

【leetcode两题选手】MySQL类题目(一)

作者头像
看、未来
发布2020-08-25 11:53:22
3940
发布2020-08-25 11:53:22
举报
文章被收录于专栏:CSDN搜“看,未来”
在这里插入图片描述
在这里插入图片描述

文章目录
  • 题一(组合两个表)
  • 题解
    • 方法:使用 outer join
  • 收获
    • 多表联结
  • 题二:第二高的薪水
  • 题解
    • 方法:使用 IFNULL 和 LIMIT 子句
  • 收获

题一(组合两个表)

表1: Person

代码语言:javascript
复制
+-------------+---------+
| 列名         | 类型     |
+-------------+---------+
| PersonId    | int     |
| FirstName   | varchar |
| LastName    | varchar |
+-------------+---------+
PersonId 是上表主键

> 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/combine-two-tables
> 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

表2: Address

代码语言:javascript
复制
+-------------+---------+
| 列名         | 类型    |
+-------------+---------+
| AddressId   | int     |
| PersonId    | int     |
| City        | varchar |
| State       | varchar |
+-------------+---------+
AddressId 是上表主键

> 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/combine-two-tables
> 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

编写一个 SQL 查询,满足条件:无论 person 是否有地址信息,都需要基于上述两表提供 person 的以下信息:

代码语言:javascript
复制
FirstName, LastName, City, State

题解

我没题解,我菜。

方法:使用 outer join

因为表 Address 中的 personId 是表 Person 的外关键字,所以我们可以连接这两个表来获取一个人的地址信息。 考虑到可能不是每个人都有地址信息,我们应该使用 outer join 而不是默认的 inner join。

代码语言:javascript
复制
select FirstName, LastName, City, State
from Person left join Address
on Person.PersonId = Address.PersonId
;
> 作者:LeetCode
> 链接:https://leetcode-cn.com/problems/combine-two-tables/solution/zu-he-liang-ge-biao-by-leetcode/
> 来源:力扣(LeetCode) 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

注意:如果没有某个人的地址信息,使用 where 子句过滤记录将失败,因为它不会显示姓名信息。

收获

题解没有,要是连收获都没有那不是白忙活一场。

多表联结

涉及到多表查询,需要用到联结。

多表的联结又分为以下几种类型:

代码语言:javascript
复制
1)左联结(left join),联结结果保留左表的全部数据

2)右联结(right join),联结结果保留右表的全部数据

3)内联结(inner join),取两表的公共数据
在这里插入图片描述
在这里插入图片描述

底下那俩,各位自行实现,反正我是实现了。

题二:第二高的薪水

编写一个 SQL 查询,获取 Employee 表中第二高的薪水(Salary) 。

代码语言:javascript
复制
+----+--------+
| Id | Salary |
+----+--------+
| 1  | 100    |
| 2  | 200    |
| 3  | 300    |
+----+--------+

例如上述 Employee 表,SQL查询应该返回 200 作为第二高的薪水。如果不存在第二高的薪水,那么查询应返回 null。

代码语言:javascript
复制
+---------------------+
| SecondHighestSalary |
+---------------------+
| 200                 |
+---------------------+

> 来源:力扣(LeetCode)
> 链接:https://leetcode-cn.com/problems/second-highest-salary
> 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解

方法:使用 IFNULL 和 LIMIT 子句

解决 “NULL” 问题的另一种方法是使用 “IFNULL” 函数,如下所示。

代码语言:javascript
复制
SELECT
    IFNULL(
      (SELECT DISTINCT Salary
       FROM Employee
       ORDER BY Salary DESC
        LIMIT 1 OFFSET 1),
    NULL) AS SecondHighestSalary

> 作者:LeetCode
> 链接:https://leetcode-cn.com/problems/second-highest-salary/solution/di-er-gao-de-xin-shui-by-leetcode/
> 来源:力扣(LeetCode) 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

收获

IFNULL(expression, alt_value) 如果第一个参数的表达式 expression 为 NULL,则返回第二个参数的备用值(此题中是返回null)。 expression是table的时候要加括号

distinct: 去重一样的Salary

limit:限返回的个数 offset:跳过几个 limit 1 offset 1:返回一个结果,跳过一个 例如返回第三高就是:limit 1 offset 2

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 题一(组合两个表)
  • 题解
    • 方法:使用 outer join
    • 收获
      • 多表联结
      • 题二:第二高的薪水
      • 题解
        • 方法:使用 IFNULL 和 LIMIT 子句
        • 收获
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档