EXISTS 与 NOT EXISTS 的用法及返回结果
(1)SELECT * FROM `datatower-all`.TMP_DWD_POI t1
WHERE EXISTS (
SELECT 1 FROM `datatower-all`.DWD_POI t WHERE t.POI_GRP_PHYSICAL_ID='100111'
)
解析:当DWD_POI表中有POI_GRP_PHYSICAL_ID='100111'的记录时,返回TMP_DWD_POI表的所有记录;当DWD_POI表中没有POI_GRP_PHYSICAL_ID='100111'的记录时,则无记录返回。
(主查询和exists的子查询无关联)
(2)SELECT * FROM `datatower-all`.TMP_DWD_POI t1
WHERE NOT EXISTS (
SELECT 1 FROM `datatower-all`.DWD_POI t WHERE t.POI_GRP_PHYSICAL_ID='100111'
)
解析:当DWD_POI表中有POI_GRP_PHYSICAL_ID='100111'的记录时,则无记录返回;当DWD_POI表中没有POI_GRP_PHYSICAL_ID='100111'的记录时,返回TMP_DWD_POI表的所有记录。
(主查询和exists的子查询无关联)
(3)SELECT * FROM `datatower-all`.TMP_DWD_POI t1
WHERE EXISTS (
SELECT 1 FROM `datatower-all`.DWD_POI t WHERE t.SOURCE_ID = t1.SOURCE_ID AND t.SOURCE_SYS=t1.SOURCE_SYS
AND t.POI_GRP_PHYSICAL_ID='100111'
)
解析:当DWD_POI表中有t.SOURCE_ID = t1.SOURCE_ID AND t.SOURCE_SYS=t1.SOURCE_SYS AND t.POI_GRP_PHYSICAL_ID='100111'的记录时,返回TMP_DWD_POI表中与DWD_POI表中SOURCE_ID相同,SOURCE_SYS相同,POI_GRP_PHYSICAL_ID='100111'的记录,相当于返回TMP_DWD_POI表相对于NOT EXISTS后子查询的交集。
当DWD_POI表中没有t.SOURCE_ID = t1.SOURCE_ID AND t.SOURCE_SYS=t1.SOURCE_SYS AND t.POI_GRP_PHYSICAL_ID='100111'的记录时,则无记录返回。
(主查询和exists的子查询有关联)
(4)SELECT * FROM `datatower-all`.TMP_DWD_POI t1
WHERE NOT EXISTS (
SELECT 1 FROM `datatower-all`.DWD_POI t WHERE t.SOURCE_ID = t1.SOURCE_ID AND t.SOURCE_SYS=t1.SOURCE_SYS
AND t.POI_GRP_PHYSICAL_ID='100111'
)
解析:当DWD_POI表中有t.SOURCE_ID = t1.SOURCE_ID AND t.SOURCE_SYS=t1.SOURCE_SYS AND t.POI_GRP_PHYSICAL_ID='100111'的记录时,返回TMP_DWD_POI表中除去与NOT EXISTS后子查询相同记录后的记录,相当于返回TMP_DWD_POI表相对于NOT EXISTS后子查询的补集。
当DWD_POI表中没有t.SOURCE_ID = t1.SOURCE_ID AND t.SOURCE_SYS=t1.SOURCE_SYS AND t.POI_GRP_PHYSICAL_ID='100111'的记录时,返回TMP_DWD_POI表中所有记录。
(主查询和exists的子查询有关联)
判断主查询和exists的子查询是否有关联的方法:查看子查询的where条件中是否同时包含了子查询表的字段和主查询表的字段,若是,则说明进行了关联,若只有子查询表的字段,则说明未进行关联)
EXISTS 与 NOT EXISTS 的用法及返回结果的更多相关文章
- oracle中的exists 和not exists 用法 in与exists语句的效率问题
博文来源(oracle中的exists 和not exists 用法):http://chenshuai365-163-com.iteye.com/blog/1003247 博文来源( in与exi ...
- sql中exists和not exists的用法
该文转载自:http://www.cnblogs.com/mytechblog/articles/2105785.html sql中exists,not exists的用法 exists : 强调的是 ...
- MySQL exists 和 not exists 的用法
有一个查询如下: 1 SELECT c.CustomerId, c.CompanyName 2 FROM Customers c 3 WHERE EXISTS( 4 SELECT ...
- 用 EXISTS 或 NOT EXISTS 用法
项目中遇到这么个情况: t1表 和 t2表 都是150w条数据,600M的样子,都不算大. 但是这样一句查询 ↓ select * from t1 where phone not in (selec ...
- MySQL 子查询 EXISTS 和 NOT EXISTS(转)
MySQL EXISTS 和 NOT EXISTS 子查询 MySQL EXISTS 和 NOT EXISTS 子查询语法如下: SELECT ... FROM table WHERE EXISTS ...
- (转)sql中 in 、not in 、exists、not exists 用法和差别
exists (sql 返回结果集为真) not exists (sql 不返回结果集为真) 如下: 表A ID NAME 1 A1 2 A2 3 A3 表B ID AI ...
- SQL中exists、not exists以及in、not in的区别和使用
exists : 强调的是是否返回结果集,不要求知道返回什么, 比如: select name from student where sex = 'm' and mark exists(selec ...
- 转【】浅谈sql中的in与not in,exists与not exists的区别_
浅谈sql中的in与not in,exists与not exists的区别 1.in和exists in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表 ...
- 浅谈sql中的in与not in,exists与not exists的区别
转 浅谈sql中的in与not in,exists与not exists的区别 12月12日北京OSC源创会 —— 开源技术的年终盛典 » sql exists in 1.in和exists ...
- MySQL 子查询 EXISTS 和 NOT EXISTS
MySQL EXISTS 和 NOT EXISTS 子查询 MySQL EXISTS 和 NOT EXISTS 子查询语法如下: SELECT ... FROM table WHERE EXISTS ...
随机推荐
- <构建之法>8,9,10章的读后感
第八章 这一章主要讲的是需求分析,主要介绍在客户需求五花八门的情况下,软件团队如何才能准确而全面地找到这些需求. 第九章 问题:我们现在怎样培养才能成为一名合格的PM呢? 第十章 问题:如果典型用户吴 ...
- Java与JavaScript 完美实现字符串拆分(利用数组存储)与合并的互逆操作
Java: String typeStr = "1,2"; String[] typeArray = typeStr.split(","); typeStr = ...
- js返回值 数组去重
function myfun(arr){ var arr1 = new Array(); var len = arr.length; ;i <len ;i++){ ) { arr1.push(a ...
- angular4 组件通讯、生命周期
主要通讯形式 父组件通过属性绑定到子组件,子组件通过事件传递参数到父组件 父组件通过局部变量获取子组件的引用 父组件使用@ViewChild获取子组件的引用 两个不相关联的组件使用中间人模式交互 终极 ...
- 【Mysql】—— 索引的分类
注意:索引是在存储引擎中实现的,也就是说不同的存储引擎,会使用不同的索引.MyISAM和InnoDB存储引擎:只支持BTREE索引,也就是说默认使用BTREE,不能够更换.MEMORY/HEAP存储引 ...
- ActiveMA在CentOS7下的安装
下载:apache-activemq-5.14.0-bin.tar.gz http://activemq.apache.org/activemq-5157-release.html Getting t ...
- python之pygal:掷一个骰子统计次数并以直方图形式显示
源码如下: # pygal包:生成可缩放的矢量图形文件,可自适应不同尺寸的屏幕显示 # 安装:python -m pip intall pygal-2.4.0-py2.py3-none-any.whl ...
- 洛谷P3588 [POI2015]PUS
题面 sol:说了是线段树优化建图的模板... 就是把一整个区间的点连到一个点上,然后用那个点来连需要连一整个区间的点就可以了,就把边的条数优化成n*log(n)了 #include <queu ...
- Redis之发布订阅
一 什么是发布订阅 发布订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖它的对象都将得到通知 Redis 发布订阅(pub/sub)是一种消息通信模式: ...
- Java 8新特性之 Base64(八恶人-7)
"General" 我是个将军 “ You, sir a hyena. I hava no wish to speak to you.” “你就是一个土狗,你不配跟我说话” 一. ...