Mysql应用MySQL中表子查询与关联子查询的基础学习教程

Mysql应用MySQL中表子查询与关联子查询的基础学习教程,第1张

概述介绍《Mysql应用MySQL中表查询关联子查询的基础学习教程》开发教程,希望对您有用。

《MysqL应用MysqL中表子查询与关联子查询的基础学习教程》要点:
本文介绍了MysqL应用MysqL中表子查询与关联子查询的基础学习教程,希望对您有用。如果有疑问,可以联系我们。

MysqL 表子查询
表子查询是指子查询返回的结果集是 N 行 N 列的一个表数据.
MysqL 表子查询实例
下面是用于例子的两张原始数据表:
article 表:
MysqL必读

MysqL必读

blog 表:
MysqL必读

MysqL必读

sql 如下:
MysqL必读

SELECT * FROM article WHERE (Title,content,uID) IN (SELECT Title,uID FROM blog)

查询返回结果如下所示:
MysqL必读

MysqL必读

该 sql 的意义在于查找 article 表中指定的字段同时也存在于 blog 表中的所有的行(注意 = 比较 *** 作符换成了 IN),实际上等同于下面的条件语句:
MysqL必读

SELECT * FROM article,blog WHERE (article.Title=blog.Title AND article.content=blog.content AND article.uID=blog.uID)

实际上,后面的语句是经过 MysqL 优化的而效率更高,或者也可以使用 MysqL JOIN 表连接来实现.在此使用该例子只是为了便于描述表子查询的用法.MysqL必读

MysqL 关联子查询
关联子查询是指一个包含对表的引用的子查询,该表也显示在外部查询中.通俗一点来讲,就是子查询引用到了主查询的数据数据.
以一个实际的例子来理解关联子查询:
article 文章表:
MysqL必读

MysqL必读

user 用户表:
MysqL必读

MysqL必读

我们要查出 article 表中的数据,但要求 article 中的某个或某些字段与 user 表字段有逻辑关系(本例为 uID 相等).sql 语句如下:
MysqL必读

SELECT * FROM article WHERE uID IN(SELECT uID FROM user WHERE article.uID = user.uID)

返回查询结果如下:
MysqL必读

MysqL必读

将该例 sql 与如下语句比较更能看出关联子查询与普通子查询的区别:
MysqL必读

SELECT * FROM article WHERE uID IN(SELECT uID FROM user)

在本实例中,虽然两个 sql 执行后的返回结果都一样,但它们的实现过程是完全不一样的.后者(普通子查询)实际被执行为:
MysqL必读

SELECT * FROM article WHERE uID IN(1,2,3)

但在关联子查询中,是无法单独执行子查询语句的.其实际流程大致为:MysqL必读

先做外部主查询; 将主查询的值传入子查询并执行; 子查询再将查询结果返回主查询,主查询根据返回结果完成最终的查询.

这个执行流程类似于 EXISTS 子查询,实际上某些情况下 MysqL 就是将关联子查询重写为 EXISTS 子查询来执行的.MysqL必读

MysqL 关联子查询效率
很明显,一般情况下关联子查询的效率是比较低下的,实际上本例中的关联子查询例子也仅是为了演示关联子查询的原理及用法.如果可以的话,关联子查询尽量使用 JOIN 或其他查询来代替.如本例中,使用 INNER JOIN 来替换的 sql 为:
MysqL必读

SELECT article.* FROM article INNER JOIN user ON article.uID = user.uID

注意:此处只是为了演示用 INNER JOIN 替换关联子查询的样例,并非表名这种处理是最优处理.MysqL必读

总结

以上是内存溢出为你收集整理的Mysql应用MySQL中表子查询与关联子查询的基础学习教程全部内容,希望文章能够帮你解决Mysql应用MySQL中表子查询与关联子查询的基础学习教程所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1163088.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存