当前位置: 首页 > news >正文

力扣-寻找用户推荐人

大家好,我是空空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 则返回第一个参数的值。


相关文章:

  • Kafka(7):生产者详解
  • Interview系列 - 06 Java | ArrayList底层源码分析 | 遍历集合时如何删除集合中的元素
  • redis(win版)
  • 【什么程度叫熟悉linux系统】
  • 带您了解TiDB MySQL数据库中关于日期、时间的坑
  • 为什么不建议用 equals 判断对象相等?
  • C/C++ 中#define 的妙用,让代码更美一些
  • 缺少IT人员的服装行业该如何进行数字化转型?
  • Spring Cloud Nacos源码讲解(二)- Nacos客户端服务注册源码分析
  • 复旦发布国内首个类ChatGPT模型MOSS,和《流浪地球》有关?
  • MyBatis基于XML的详细使用——动态sql
  • Qt 开发使用VSCode 笔记2
  • 算法分析详解
  • 进程间通信(二)/共享内存
  • 边玩边学,13个 Python 小游戏真有趣啊(含源码)
  • 「TCG 规范解读」第7章 TPM工作组 TPM 总结
  • 七大排序经典排序算法
  • 带你一步步搭建Web自动化测试框架
  • 踩大坑:json格式存储wav二进制内容
  • ChatGPT 简介
  • 米价暴涨,日本游客赴韩国“淘米”
  • 碳市场扩围推动汽车行业降碳,用真实碳数据量化成本是关键
  • 分析|开门红:一季度GDP增长5.4%超预期,市场活力信心增强
  • 法国决定驱逐12名阿尔及利亚使馆工作人员并召回驻阿大使
  • 深圳机器人“十三太保”亮相上海,所为何事?
  • 三河市委书记付顺义简历已从三河市政府网站撤下