欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 文化 > not in not exists

not in not exists

2025/3/15 10:38:28 来源:https://blog.csdn.net/htydowd/article/details/146262783  浏览:    关键词:not in not exists

select id1 from test1 where id1 not  in (select id2 from test2)

第一步: 执行 子查询 select id2 from test2, 子查询 返回一个 结果 集

第二部: 根据 主查询的 条件, 将 主表中的 每一行 都和 结果集进行比较

第三步: 如果 比较的结果是 TRUE,则表示不存在结果集中,FALSE 表示 存在结果集中

如果 结果集中 存在 NULL 值,则 整个查询 不返回任何结果。因为任何值与 NULL 比较 结果为 UNKNOWN,所以 不会返回。

select * FROM test1 where NOT EXISTS (select * from test2 where id2 = id1 )

1. 相关子查询:NOT EXISTS 子查询通常是一个相关子查询,这意味着它会引用外部查询中的字段。次外部查询处理一时子查询都会重新执行一次。  
2. 检查存在性:NOT EXISTS 子查询的目的是检查子查询是否返回任何行。如果子查询返回至少一行,则 NOT EXISTS 返回 FALSE;如果子查询不返回任何行,则 NOT EXISTS 返回 TRUE。  
3。 短路评估:一旦子查询找到匹配的行,NOT EXISTS 就会立即返回 FALSE,而不会继续扫描剩余的行。这种短路评估提高了查询效率。  
4. 处理 NULL 值:与 NOT IN 不同,NOT EXISTS 不会受到 NULL 值的影响。即使子查询结果中包含 NULL 值,NOT EXISTS 仍然可以正常工作,因为它只检查是否存在行,而不关心具体的值

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词