LeetCode MySQL 刷题条记 (一)

121 阅读3分钟

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

题目: 595. 大的国家

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| name        | varchar |
| continent   | varchar |
| area        | int     |
| population  | int     |
| gdp         | int     |
+-------------+---------+

需求

name 是这张表的主键。 这张表的每一行提供:国家名称、所属大陆、面积、人口和 GDP 值。 如果一个国家满足下述两个条件之一,则认为该国是 大国 : 面积至少为 300 万平方公里(即,3000000 km2),或者 人口至少为 2500 万(即 25000000) 编写一个 SQL 查询以报告 大国 的国家名称、人口和面积。 按 任意顺序 返回结果表。 查询结果格式如下例所示。

解析

# Write your MySQL query statement below

select name ,population,area from  world where area >='3000000' or population  >='25000000'

题目: 1757. 可回收且低脂的产品

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| product_id  | int     |
| low_fats    | enum    |
| recyclable  | enum    |
+-------------+---------+
product_id 是这个表的主键。
low_fats 是枚举类型,取值为以下两种 ('Y', 'N'),其中 'Y' 表示该产品是低脂产品,'N' 表示不是低脂产品。
recyclable 是枚举类型,取值为以下两种 ('Y', 'N'),其中 'Y' 表示该产品可回收,而 'N' 表示不可回收。

需求

写出 SQL 语句,查找既是低脂又是可回收的产品编号。 返回结果 无顺序要求

解析

# Write your MySQL query statement below

select product_id from products where low_fats ='y' and recyclable = 'y'

题目: 584. 寻找用户推荐人

+------+------+-----------+
| id   | name | referee_id|
+------+------+-----------+
|    1 | Will |      NULL |
|    2 | Jane |      NULL |
|    3 | Alex |         2 |
|    4 | Bill |      NULL |
|    5 | Zack |         1 |
|    6 | Mark |         2 |
+------+------+-----------+

里面保存了所有客户信息和他们的推荐人

需求

写一个查询语句,返回一个客户列表,列表中客户的推荐人的编号都 **不是 **2。

解析

# Write your MySQL query statement below
select name from customer where id  not in (select id  from customer where  referee_id= '2')

题目:183. 从不订购的客户

+----+-------+
| Id | Name  |
+----+-------+
| 1  | Joe   |
| 2  | Henry |
| 3  | Sam   |
| 4  | Max   |
+----+-------+

+----+------------+
| Id | CustomerId |
+----+------------+
| 1  | 3          |
| 2  | 1          |
+----+------------+

某网站包含两个表,Customers 表和 Orders 表。

需求:

编写一个 SQL 查询,找出所有从不订购任何东西的客户。

解析

# Write your MySQL query statement below

select  name as 'Customers' from Customers  where id not in (select CustomerId  from orders) 

知识点

  • where 组合子句(数据过滤)

在mysql语句中可以使用多种组合过滤的方式,其实包含and 、or 、in、not 然而在上述题目中用到这些知识点

  • and
    • 定义:AND指示DBMS只返回满足所有给定条件的行
    • 语句格式: select 列名 from 表 where 条件(eg : key1=a and key2=b ) ;
  • or
    • 定义:OR操作符告诉DBMS匹配任一条件而不是同时匹配两个条件
    • 语句格式:select 列名 from 表 where 条件(eg : key1=a or key2=b ) ;
  • in
    • 定义:IN操作符用来指定条件范围,范围中的每个条件都可以进行匹配
    • 语句格式:select 列名 from 表 where 条件(eg : key1 in(a,b) ) ;
  • not
    • WHERE子句中用来否定后跟条件的关键字
    • 语句格式:select 列名 from 表 where 条件(eg : key1 not in(a,b) ) ;

在这些操作符中,他们也是有优先级排列的,优先级:() > AND > OR,在sql语句中,SQL(像多数语言一样)在处理OR操作符前,优先处理AND操作符

  • 别名使用
    • 别名在字段中使用as
    • 栗子: select concat(vend_name,'(',vend_country,')') AS vend_title from 表名 order by 列名;