说明本文题目全部来源于力扣,点击标题即可跳转
选择基础
选择是数据库最基本的操作,主要的格式是
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
,所以我们的查找条件就是排除掉这些客户。
先查询出订购过的客户的ID
SQL语句如下
SELECT CustomerId FROM Orders
这是我们筛查出来的,我们要查找的不是这些客户,所以我们使用NOT IN
语句,为什么是IN
而不是=
,等于只有一个值,而IN
代表的是包含
所以答案如下
SELECT name AS 'Customers'
FROM Customers
WHERE id not in (
SELECT CustomerId FROM Orders
);