大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。
文章目录
- 前言
- 一、题目:584. 寻找用户推荐人
- 二、解题
- 1.正确示范①
- 提交SQL
- 运行结果
- 2.正确示范②
- 提交SQL
- 运行结果
- 3.正确示范③
- 提交SQL
- 运行结果
- 4.其他
- 总结
前言
一、题目: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。
对于上面的示例数据,结果为:
+------+
| name |
+------+
| Will |
| Jane |
| Bill |
| Zack |
+------+
二、解题
1.正确示范①
提交SQL
select name
from customer
where
(referee_id<>2
or referee_id is null
);
或者
select name
from customer
where
(referee_id!=2
or referee_id is null
);
或者
select name
from customer
where
(referee_id not in(2)
or referee_id is null
);
运行结果
2.正确示范②
提交SQL
select name from customer
where id not in (
select id from customer
where referee_id=2
);
运行结果
3.正确示范③
提交SQL
select name
from customer
where ifnull(referee_id,0)!=2
或者
select name
from customer
where ifnull(referee_id,0)<>2
或者
select name
from customer
where ifnull(referee_id,0) not in (2)
运行结果
4.其他
总结
正确示范①思路:
限定推荐人编号不等于2或者推荐人编号为NULL;
正确示范②思路:
先把推荐人编号是2的客户id找出来,再从全部客户中把客户id是这部分的客户排除掉;
正确示范③思路:
先把推荐人编号为NULL的编号转化为0,再限定推荐人编号不等于2。
知识点:
MySQL中<>是不等号的意思。
sql中有两种方式表示不等于,一种是"<>“(不含引号),另一种是”!="(不含引号),用法是一样的。都会排除NULL的行。
IFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。