1

我有以下表格:

Table 1 : Contacts
Fields : id  first_name

Values : 

1    Reeta
2    Rohan
3    John 

Table 2 : email (it contains contact_id of contacts table)
Fields : id   contact_id  email_address

Values :

1  1  r@gmail.com
2  2  r@gmail.com
3  3  j@gmail.com

I want to display all duplicates by email. Like this:

cont_id  first_name  email_address

   1        Reeta  r@gmail.com
   2        Rohan  r@gmail.com

这是我的查询:

select contact_id 
from contacts 
where email_address IN (
  SELECT S.email_address 
  FROM  contacts R
  INNER JOIN email
    ON R.id = S.contact_id 
  Group By email_address
  Having Count(S.id) > 1
); 

查询需要很长时间才能执行大量记录。然而,内部查询工作得更快,但外部查询却不行。请帮忙。

4

1 回答 1

1

是的,这是 MySQL 查询优化器的问题。事情是——因为 MySQL 与子查询IN (subquery)是一样的。即使子查询返回很少的值计数,MySQL 也不会对此进行优化,这些值在正常情况下很容易通过索引进行比较(如果它存在于我们正在执行的列上)。= ANY ()IN

不要将其与IN (<static values list>)- 这是完全不同的情况,当 MySQLIN不将其视为特定类型的子查询,而是将其视为比较运算符时 - 因此使用索引。

因此,一种可能的解决方案是 - 分离您的子查询,以便它返回一些值列表,然后将该列表替换为,因为被视为比较运算符而进行IN ()索引扫描。IN但是,在某些情况下,可以通过将子查询替换为JOIN. 并非在所有情况下都是可能的,因此上述解决方案将适用于常见的非平凡情况。

于 2014-02-25T09:54:46.837 回答