力扣SQL专向----SQL入门第一天

文章目录

    • 选择基础
      • 595.大的国家
      • 1757.可回收且低脂的产品
      • 584.寻找用户推荐人
      • 183.从不订购的客户

说明本文题目全部来源于力扣,点击标题即可跳转

选择基础

选择是数据库最基本的操作,主要的格式是
SELECT 选择的字段
FROM 来自哪个表
WHERE选择的条件(这个是可选项)
其中WHERE虽然是可选项,也是内容较多,而且用来丰富选择功能的重要知识点!
本次力扣为我们准备的四道“选择”入门题涉及比较运算符、和条件语句、以及子查询

595.大的国家

题目描述
World表结构:

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| name        | varchar |
| continent   | varchar |
| area        | int     |
| population  | int     |
| gdp         | int     |
+-------------+---------+
name 是这张表的主键。
这张表的每一行提供:国家名称、所属大陆、面积、人口和 GDP 值。

如果一个国家满足下述两个条件之一,则认为该国是 大国 :

  • 面积至少为 300 万平方公里(即,3000000 km2),或者
  • 人口至少为 2500 万(即 25000000)
    题目解析
    从上面的条件我们需要用到比较运算符>=和条件语句OR
SELECT name,population,area 
FROM World
WHERE population >= 25000000 OR area >= 3000000;

1757.可回收且低脂的产品

题目描述
Products表结构:

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

题目解析
和上述题目不同的是:上面的题目只要满足一样就可以成为大国,而本题需要满足两个条件,所以我们这里使用的条件语句是AND,而根据表结构我们可以知道需要两项都满足= 'Y'

SELECT product_id
FROM Products
WHERE low_fats = 'Y' AND recyclable = 'Y';

584.寻找用户推荐人

题目描述
customer表结构

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

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

题目解析
这里我们涉及的比较运算符是!=这个大家都比较熟悉,而表格中还有NULL,这个不是字符串,而只是代表空,我们无法使用比较运算符来看表格数据是否为空,这里我们使用IS NULL代表该数据为空,同时使用OR来判定条件

SELECT name
FROM customer
WHERE referee_id != 2 OR referee_id IS NULL

183.从不订购的客户

题目描述
本题会给我们两张表
Customers

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

Orders

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

某网站包含两个表,Customers 表和 Orders 表。编写一个 SQL 查询,找出所有从不订购任何东西的客户。
题目解析
这题考到了子查询的问题。首先我们知道订购过的客户的ID,所以我们的查找条件就是排除掉这些客户。
先查询出订购过的客户的IDSQL语句如下

SELECT CustomerId FROM Orders

这是我们筛查出来的,我们要查找的不是这些客户,所以我们使用NOT IN语句,为什么是IN而不是=,等于只有一个值,而IN代表的是包含
所以答案如下

SELECT name AS 'Customers'
FROM Customers
WHERE id not in (
    SELECT CustomerId FROM Orders
);

你可能感兴趣的:(leetcode,sql)