力扣183题:从不订购客户

本文讨论了SQL查询中的NOTIN子句的局限性,以及如何使用LEFTJOIN和NOTEXISTS替代来提高效率。LEFTJOIN用于返回左表所有行,即使右表无匹配也包含NULL。NOTEXISTS则检查是否存在满足条件的行,常用于提高性能。
摘要由CSDN通过智能技术生成

题解:查找A 表中不关联在B表中的数据

select 
name as 'Customers'
from customers where id not in (select customerid from orders);

注意:not in 是比较直接的查找方式,但是存在一定的局限性,比如:

子查询效率低下: NOT IN 子句通常包含一个子查询,用于检查主查询结果中的值是否存在于子查询结果中。如果子查询返回的结果集很大,或者没有适当的索引支持,这可能会导致性能下降。

处理 NULL 值: NOT IN 子句在处理 NULL 值时可能会产生意外结果。如果子查询返回 NULL 值,整个 NOT IN 表达式可能会失败,而不是产生预期的结果。

可以使用LEFT JOIN 或者NOT EXISTS 达到相同的目的,而避免not in 带来的风险


 

LEFT JOIN 是 SQL 中用于联接两个表的一种类型,它返回左表(在语法中排在左边的表)中的所有行,以及右表(在语法中排在右边的表)中与左表中的行匹配的行。如果右表中没有匹配的行,则返回 NULL 值。

LEFT JOIN 的原理是基于笛卡尔积(Cartesian Product)和条件过滤的组合。在执行 LEFT JOIN 时,数据库引擎首先生成左表和右表的笛卡尔积,即左表中的每一行都与右表中的每一行组合。然后,根据指定的连接条件,筛选出满足条件的行,形成最终的联接结果。

例如,假设我们有两个表 A 和 B,我们想要执行 A LEFT JOIN B,连接条件是 A 中的某一列与 B 中的某一列相等。LEFT JOIN 将返回 A 中的所有行,以及与 A 中的行匹配的 B 中的行。如果在 B 中没有与 A 中的行匹配的行,则在结果中相应位置填充 NULL 值。

这种联接类型的特点是,即使右表中没有匹配的行,左表中的行仍然会被包括在结果中。这使得 LEFT JOIN 特别适用于需要保留左表中所有行的情况,即使右表中没有匹配的情况下。

SELECT name AS 'Customers'
FROM customers
LEFT JOIN orders ON customers.id = orders.customerid
WHERE orders.customerid IS NULL;

 

NOT EXISTS 是 SQL 中用于子查询的一种条件谓词,它用于检查是否存在满足特定条件的行。如果子查询返回空结果集(即没有满足条件的行),则 NOT EXISTS 条件为真,否则为假。

NOT EXISTS 的原理是基于子查询的执行。当执行包含 NOT EXISTS 的查询时,数据库引擎首先执行子查询,并检查子查询返回的结果是否为空。如果结果为空,则主查询中的 NOT EXISTS 条件为真,否则为假。

一般来说,NOT EXISTS 子查询会利用索引来提高性能,因为它只需要判断是否存在满足条件的行,而不需要返回实际数据。这使得 NOT EXISTS 在某些情况下比其他方法更有效率。

例如,假设我们有一个主查询和一个子查询,我们想要检查在子查询中是否存在满足某一条件的行,如果不存在则返回主查询中的结果。NOT EXISTS 子查询将返回一个布尔值,指示是否存在满足条件的行,然后主查询根据这个布尔值来确定是否包括相应的结果。

SELECT name AS 'Customers'
FROM customers AS c
WHERE NOT EXISTS (
    SELECT 1
    FROM orders AS o
    WHERE o.customerid = c.id
);

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值