详细讲述MySQL中的子查询操作

2019-01-05 09:57:38王振洲

使用explain查看一下,就会得到以下内容:

201541491929351.png (1082×140)

我们可以很明显的看到,存在一个相关的子查询(DEPENDENT SUBQUERY)。可以看到EXISTS和IN是非常相似的,那么它们之间的区别是什么呢?

关于IN和EXISTS的主要区别在于三值逻辑的判断上。EXISTS总是返回TRUE或FALSE,而对于IN,除了TRUE、FALSE值外,还有可能对NULL值返回UNKNOWN。但是在过滤器中,UNKNOWN的处理方式与FALSE相同,因此使用IN与使用EXISTS一样,SQL优化器会选择相同的执行计划。

说到了IN和EXISTS几乎是一样的,但是,就不得不说到NOT IN和NOT EXISTS,对于输入列表中包含NULL值时,NOT EXISTS和NOT IN之间的差异就表现的非常大了。输入列表包含NULL值时,IN总是返回TRUE和UNKNOWN,因此NOT IN就会得到NOT TRUE和NOT UNKNOWN,即FALSE和UNKNOWN。

mysql> select 'c' NOT IN ('a', 'b', NULL)G;

执行一下上述代码,看看结果。你就会感到惊讶。
派生表

上面也说到了,在子查询返回的值中,也可能返回一个表,如果将子查询返回的虚拟表再次作为FROM子句的输入时,这就子查询的虚拟表就成为了一个派生表。语法结构如下:

FROM (subquery expression) AS derived_table_alias

由于派生表是完全的虚拟表,并没有也不可能被物理地具体化。
总结

总算总结的差不多了,当然了子查询的东西还是有很多的,不可能一篇文章就能总结的完的,这里只是把一些基本的概念,常用的知识点进行了总结,关于将子查询使用到update、delete和insert语句中的用法,我这里并没有涉及,大体上都是大同小异的。知识这个东西,展开了,就没有头了,还是需要适可而止,适当的进行深度的挖掘,但是深度最好不要超过2,关于这个2如何定义,自行把握。好了,这篇文章就到此为止了,我们下一篇见。

您可能感兴趣的文章:

Mysql子查询IN中使用LIMIT应用示例MySQL中表子查询与关联子查询的基础学习教程详解MySql基本查询、连接查询、子查询、正则表达查询MySQL子查询的几种常见形式介绍MySQL的子查询中FROM和EXISTS子句的使用教程mysql in语句子查询效率慢的优化技巧示例浅谈MySQL中的子查询优化技巧mysql优化系列 DELETE子查询改写优化MySQL优化之使用连接(join)代替子查询MYSQL子查询和嵌套查询优化实例解析MySQL子查询操作实例详解