LeetCode MySQL 刷题条记 (五)

78 阅读3分钟

「4月日新计划更文活动」

题目:175. 组合两个表

+-------------+---------+
| 列名         | 类型     |
+-------------+---------+
| PersonId    | int     |
| FirstName   | varchar |
| LastName    | varchar |
+-------------+---------+
personId 是该表的主键列。
该表包含一些人的 ID 和他们的姓和名的信息。


+-------------+---------+
| 列名         | 类型    |
+-------------+---------+
| AddressId   | int     |
| PersonId    | int     |
| City        | varchar |
| State       | varchar |
+-------------+---------+
addressId 是该表的主键列。
该表的每一行都包含一个 ID = PersonId 的人的城市和州的信息。

需求

编写一个SQL查询来报告 Person 表中每个人的姓、名、城市和州。如果 personId 的地址不在 Address 表中,则报告为空  null 。

以 任意顺序 返回结果表

解析

# Write your MySQL query statement below

select FirstName as firstName  , LastName as lastName ,Address.city,Address.state from Person Left outer  Join Address  on  Person.personId = Address.personId 
# Write your MySQL query statement below

select Person.FirstName as firstName  ,Person.LastName as lastName ,city,state from Address right outer  Join Person  on  Person.personId = Address.personId 

题目:1581. 进店却未进行过交易的顾客

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| visit_id    | int     |
| customer_id | int     |
+-------------+---------+
visit_id 是该表的主键。
该表包含有关光临过购物中心的顾客的信息。

+----------------+---------+
| Column Name    | Type    |
+----------------+---------+
| transaction_id | int     |
| visit_id       | int     |
| amount         | int     |
+----------------+---------+
transaction_id 是此表的主键。
此表包含 visit_id 期间进行的交易的信息。

需求

有一些顾客可能光顾了购物中心但没有进行交易。请你编写一个 SQL 查询,来查找这些顾客的 ID ,以及他们只光顾不交易的次数。

返回以 任何顺序 排序的结果表。

解析

# Write your MySQL query statement below

select  customer_id ,count(visit_id) as count_no_trans    from Visits  where visit_id not in(select distinct visit_id from Transactions ) group by customer_id  

题目:1148. 文章浏览 I

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| article_id    | int     |
| author_id     | int     |
| viewer_id     | int     |
| view_date     | date    |
+---------------+---------+
此表无主键,因此可能会存在重复行。
此表的每一行都表示某人在某天浏览了某位作者的某篇文章。
请注意,同一人的 author_id 和 viewer_id 是相同的。

需求

请编写一条 SQL 查询以找出所有浏览过自己文章的作者,结果按照 id 升序排列。

解析

# Write your MySQL query statement below

select distinct(author_id) as id  from Views   where author_id =viewer_id  order by author_id

知识点

left outer join 函数

  • 定义: Left outer join函数是一种在关系型数据库中使用的表连接查询操作。它在左侧表中查找所有记录并且匹配右侧表中符合条件的记录。如果右侧表中没有符合条件的记录,则左侧表中的所有记录都会被返回。
  • 语句格式SELECT 列名 FROM 表1 LEFT OUTER JOIN 表2 ON 表2.字段号=表1.字段号;
  • 解释:LEFT指出的是OUTER JOIN左边的表
  • 注意⚠️:选择左边表中的所有行就使用LEFT,否则反之

right outer join 函数

  • 定义:Right指出的是OUTER JOIN右边的表
  • 语句格式SELECT 列名 FROM 表1 RIGHT OUTER JOIN 表2 ON 表2.字段号=表1.字段号;
  • 解释:Right 指出的是OUTER JOIN右边的表
  • 注意⚠️:选择右边表中的所有行就使用RIGHT,否则反之

where not in 函数

  • 定义:WHERE NOT IN是一种条件子句。它通常被用于SELECT语句中,以从表格中选择不符合条件的行
  • 作用:WHERE NOT IN语句的作用是将不符合条件的行从结果集中删除
  • 语句格式:栗子🌰1581 where visit_id not in(select distinct visit_id from Transactions )