关联子查询是指一个包含对表的引用的子查询,该表也显示在外部查询中。通俗一点来讲,就是子查询引用到了主查询的数据数据。
以一个实际的例子来理解关联子查询:
aid | title | content | uid |
---|---|---|---|
1 | 文章1 | 文章1正文内容... | 1 |
2 | 文章2 | 文章2正文内容... | 1 |
3 | 文章3 | 文章3正文内容... | 2 |
4 | 文章4 | 文章4正文内容... | 4 |
uid | username | |
---|---|---|
1 | admin | admin@520mg.com |
2 | 小明 | xiao@163.com |
3 | Jack | jack@gmail.com |
我们要查出 article 表中的数据,但要求 article 中的某个或某些字段与 user 表字段有逻辑关系(本例为 uid 相等)。SQL 语句如下:
SELECT * FROM article WHERE uid IN(SELECT uid FROM user WHERE article.uid = user.uid)
返回查询结果如下:
aid | title | content | uid |
---|---|---|---|
1 | 文章1 | 文章1正文内容... | 1 |
2 | 文章2 | 文章2正文内容... | 1 |
3 | 文章3 | 文章3正文内容... | 2 |
将该例 SQL 与如下语句比较更能看出关联子查询与普通子查询的区别:
SELECT * FROM article WHERE uid IN(SELECT uid FROM user)
在本实例中,虽然两个 SQL 执行后的返回结果都一样,但它们的实现过程是完全不一样的。后者(普通子查询)实际被执行为:
SELECT * FROM article WHERE uid IN(1,2,3)
但在关联子查询中,是无法单独执行子查询语句的。其实际流程大致为:
这个执行流程类似于 EXISTS 子查询,实际上某些情况下 MySQL 就是将关联子查询重写为 EXISTS 子查询来执行的。