如何解决MySQL在哪里存在,mySQL如何链接行?
| 我在查询此代码时遇到问题SELECT * FROM sometable WHERE EXISTS (
SELECT 1 FROM sometable
GROUP BY relevant_field
HAVING count(*) > 1)
如果我使用JOIN,则会明确指定链接,但是在这里我没有这样做,所以我对MySQL内部发生的事情没有清晰的概念。
MySQL如何知道如何将行从内部表连接到外部表?
解决方法
根据括号中的SELECT是否返回行,查询本身将返回“ѭ1”中的所有行,或者根本不返回任何行。
换句话说,MySQL不知道如何并且也不会在此特定查询中将行从内部表链接到外部表。
相当于联接的是:
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)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。