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) 
    

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...