MySQL在哪里存在,mySQL如何链接行?

Posted

技术标签:

【中文标题】MySQL在哪里存在,mySQL如何链接行?【英文标题】:MySQL where exists, how does mySQL link the rows? 【发布时间】:2011-05-26 09:50:07 【问题描述】:

我在理解这段代码时遇到了问题

SELECT * FROM sometable WHERE EXISTS (
   SELECT 1 FROM sometable
   GROUP BY relevant_field
   HAVING count(*) > 1) 

如果我使用 JOIN,我会明确指定链接,但这里我没有,所以我对 mysql 内部发生的事情没有清晰的概念。

MySQL 如何知道如何将内部 sometable 的行链接到外部 sometable?

【问题讨论】:

@ypercube,因此您将连接标准转移到内部选择中的 where 子句,就像使用隐式 where join? 是的。实际上我的查询更像是WHERE relevant_field IN (SELECT relevant_field ...) 而不是JOIN。但是GROUP BY 使所有 3 个版本产生相同的结果。 【参考方案1】:

您的查询将返回来自sometable 的所有行或根本不返回任何行,具体取决于带括号的 SELECT 是否会返回行。

换句话说,MySQL 不知道如何也不会在此特定查询中将行从内部链接到外部 sometable。

相当于连接是:

SELECT * FROM sometable a WHERE EXISTS (
   SELECT 1 FROM sometable b
   WHERE a.relevant_field = b.relevant_field
   GROUP BY b.relevant_field
   HAVING count(*) > 1) 

【讨论】:

以上是关于MySQL在哪里存在,mySQL如何链接行?的主要内容,如果未能解决你的问题,请参考以下文章

使用php从mysql中取出文本如何自动添加超链接?

如何检查MySQL中是不是存在行? (即检查电子邮件是不是存在于 MySQL 中)

如果行不存在具有相同的值,如何在 Mysql 中插入行

只把.frm文件考入mysql新建数据库目录下后,用命令行窗口打开,一直显示表不存在,用repair修复也不行

在哪里可以找到 MySQL 事务日志?

如何从mysql列中存在的所有行中删除重复值[duplicate]