mysql的EXISTS使用

使用格式如下:

select * from a where exists ( 任何子查询 )

代码根据颜色分成两段,前面的是主查询,后面红色的是子查询,先主后子,主查询里面的属性可以放到子查询使用。

使用含义:

该子查询如果“有数据结果”, 查询只要返回了结果行数,则该exists()的结果为“true”

该子查询如果“没有数据结果”,查询没有返回结果行数,则该exists()的结果为“false”

这里说一下什么叫有数据结果

1.有数据结果

(1)查询全部的数据:SELECT * FROM student

(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。

使用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;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章