相关文章:
【sql】深入理解 mysql的EXISTS 语法
【sql】初识 where EXISTS
1. 使用格式如下:
select * from a where exists
( 任何子查询 )
代码根据颜色分成两段,前面的是主查询,后面红色的是子查询,先主后子
,主查询里面的属性可以放到子查询使用。
2. 使用含义:
该子查询如果“有数据结果”, 查询只要返回了结果行数,则该exists()的结果为“true”
该子查询如果“没有数据结果”,查询没有返回结果行数,则该exists()的结果为“false”
2.1 这里说一下什么叫有数据结果?
1.有数据结果
(1)查询全部的数据:SELECT * FROM studen
(2)查询全部的数据条数:SELECT COUNT(1) FROM student
(3)查询一个不存在的数据,显示数量:SELECT COUNT(1) FROM student WHERE id=888;
2.没有数据结果
查询不存在的数据记录:SELECT * FROM student WHERE id=888;
如上,只要返回的有数据结果,exists()的结果为“true”,否则就是false。
3.使用demo演示一下where exists的用法
(1)建表语句如下
SET FOREIGN_KEY_CHECKS=0;-- ----------------------------
-- Table structure for student
-- ----------------------------
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(255) DEFAULT NULL COMMENT '名字',`age` int(11) DEFAULT NULL COMMENT '年龄',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1;-- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES ('1', 'zhangsan', '18');
INSERT INTO `student` VALUES ('2', 'lisi', '19');
INSERT INTO `student` VALUES ('3', 'wangwu', '20');
(2) 建表结果如下
student表
前提:id=1存在记录,id=111不存在记录
。
(3)这三种都是返回全部记录,因为where exists子查询存在数据结果,所以返回true
SELECT * FROM student st WHERE EXISTS (SELECT * FROM student);
SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student);
SELECT * FROM student st WHERE EXISTS (SELECT COUNT(1) FROM student);
结果一二三相同:
(4)这两种,上面的那个不返回数据,下面的这个返回全部数据
SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student dd where dd.id=111);
SELECT * FROM student st WHERE EXISTS (SELECT COUNT(1) FROM student dd where dd.id=111);
结果一不返回数据:
结果二返回数据:
(5)以下四种
SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student dd where dd.id=1);
SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student dd where dd.id=111);
SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student dd where st.id=1);
SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student dd where st.id=111);
结果一:
结果二:
结果三:
结果四:
总结:(1)整体查询分为主子,前面是主查询,where exists后面是子查询,先主后子
。
EXPLAIN SELECT * FROM student st WHERE EXISTS (SELECT 1 FROM student dd where dd.id=1);
(2)子查询,有结果exists返回为true,无结果exists返回false。exists子查询返回true,主查询就正常返回全部内容,exists子查询返回false,主查询的内容就全部不返回。
(3)子查询count(1)一直有结果。即使count(1)返回0,也是有结果返回,所以where exists使用count(1)一直返回true.
(4)exists子查询使用select 1,有返回结果,子查询就返回true,没有返回结果,子查询就返回false。
(5)针对子查询使用select *,select 1,select count(1)都行,子查询返回的结果内容不重要,只要有结果就返回true,无结果返回false。
(6)子查询可以使用主查询的字段。如下:
第一个语句没有使用主查询的字段,只需要正常判断WHERE EXISTS是否有结果返回就好了。
SELECT * FROM student st
WHERE EXISTS (SELECT 1 FROM student dd where dd.id=1
);
第二个语句st.id=1
使用的是主查询的st表字段,将会限制主查询的内容。
SELECT * FROM student st
WHERE EXISTS (SELECT 1 FROM student dd where st.id=1
);
这个语句等同于
SELECT * FROM student st where st.id=1;
参考
https://blog.csdn.net/Mint6/article/details/105084644