「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 列名;