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

【MySQL】外连接 where 和 on 的区别

力扣题

1、题目地址

1158. 市场分析 I

2、模拟表

User

Column NameType
user_idint
join_datedate
favorite_brandvarchar
  • user_id 是此表主键(具有唯一值的列)。
  • 表中描述了购物网站的用户信息,用户可以在此网站上进行商品买卖。

Orders

Column NameType
order_idint
order_datedate
item_idint
buyer_idint
seller_idint
  • order_id 是此表主键(具有唯一值的列)。
  • item_id 是 Items 表的外键(reference 列)。
  • (buyer_id,seller_id)是 User 表的外键。

Items

Column NameType
item_idint
item_brandvarchar
  • item_id 是此表的主键(具有唯一值的列)。

3、要求

编写解决方案找出 每个用户的注册日期 和 在 2019 年 作为 买家订单总数
以 任意顺序 返回结果表。
查询结果格式如下。

示例 1:

输入:
Users 表:

user_idjoin_datefavorite_brand
12018-01-01Lenovo
22018-02-09Samsung
32018-01-19LG
42018-05-21HP

Orders 表:

order_idorder_dateitem_idbuyer_idseller_id
12019-08-01412
22018-08-02213
32019-08-03323
42018-08-04142
52018-08-04134
62019-08-05224

Items 表:

item_iditem_brand
1Samsung
2Lenovo
3LG
4HP

输出:

buyer_idjoin_dateorders_in_2019
12018-01-011
22018-02-092
32018-01-190
42018-05-210

4、代码编写

正确写法

SELECT a.user_id AS buyer_id,a.join_date, count(b.buyer_id) AS orders_in_2019
FROM Users aLEFT join Orders b ON a.user_id = b.buyer_id AND YEAR(b.order_date) = '2019'
GROUP BY a.user_id
| buyer_id | join_date  | orders_in_2019 |
| -------- | ---------- | -------------- |
| 1        | 2018-01-01 | 1              |
| 2        | 2018-02-09 | 2              |
| 3        | 2018-01-19 | 0              |
| 4        | 2018-05-21 | 0              |

错误写法

SELECT a.user_id AS buyer_id,a.join_date, count(b.buyer_id) AS orders_in_2019
FROM Users aLEFT join Orders b ON a.user_id = b.buyer_id
WHERE YEAR(b.order_date) = '2019'
GROUP BY a.user_id
| buyer_id | join_date  | orders_in_2019 |
| -------- | ---------- | -------------- |
| 1        | 2018-01-01 | 1              |
| 2        | 2018-02-09 | 2              |

错误分析(网友回答)

外连接时要注意 whereon 的区别:

  • on 是在连接构造临时表时执行的,不管 on 中条件是否成立都会返回主表(也就是 left join 左边的表)的内容,
  • where 是在临时表形成后执行筛选作用的,不满足条件的整行都会被过滤掉。
  • 如果这里用的是 where year(order_date)='2019' 那么得到的结果将会把不满足条件的 user_id34 的行给删掉。
  • on 的话会保留 user_id34 的行。
http://www.lryc.cn/news/265907.html

相关文章:

  • 【优化】XXLJOB修改为使用虚拟线程
  • 金蝶Apusic应用服务器 loadTree JNDI注入漏洞复现(QVD-2023-48297)
  • PromptNER: Prompt Locating and Typing for Named Entity Recognition
  • QT编写应用的界面自适应分辨率的解决方案
  • Kubernetes pod ip 暴露
  • 442. 数组中重复的数据
  • Qt/C++视频监控Onvif工具/组播搜索/显示监控画面/图片参数调节/OSD管理/祖传原创
  • word2003 open word2007+
  • windows安装、基本使用vim
  • 【SpringBoot快速入门】(1)SpringBoot的开发步骤、工程构建方法以及工程的快速启动详细讲解
  • Day69力扣打卡
  • 机器学习:手撕 AlphaGo(一)
  • ElasticSearch学习篇9_文本相似度计算方法现状以及基于改进的 Jaccard 算法代码实现
  • 大创项目推荐 深度学习+python+opencv实现动物识别 - 图像识别
  • Debezium系列之:Flink SQL消费Debezium数据格式,同步数据到下游存储系统
  • webrtc支持的最小宽度和高度
  • 虚拟机对象的创建
  • 阿里云吴结生:云计算是企业实现数智化的阶梯
  • MySQL——复合查询
  • mysql 23-3day 数据库授权(DCL)
  • OpenHarmony之内核层解析~
  • Chatgpt如何共享可以防止封号!
  • 智能优化算法应用:基于社交网络算法3D无线传感器网络(WSN)覆盖优化 - 附代码
  • thinkphp+vue+mysql酒店客房管理系统 b1g8z
  • nodejs+vue+ElementUi摄影作品图片分享工作室管理系统
  • 详解FreeRTOS:专栏总述
  • 在 linux 服务器上安装Redis数据库
  • 阿里云经济型、通用算力型、计算型、通用型、内存型云服务器最新活动报价
  • 回溯算法 典型习题
  • 14. 从零用Rust编写正反向代理, HTTP文件服务器的实现过程及参数