此 SQL 查询是不是有更有效的替代方法?

Posted

技术标签:

【中文标题】此 SQL 查询是不是有更有效的替代方法?【英文标题】:is there a more efficient alternative for this SQL query?此 SQL 查询是否有更有效的替代方法? 【发布时间】:2020-05-21 15:15:06 【问题描述】:

我正在处理一个电影数据集,该数据集包含电影、流派表和 in_genre 桥接表。 以下查询尝试查找两部电影之间的共同类型。我做了两个连接来获取流派列表和一个相交来找到常见的流派。 有没有更有效的方法?

表架构:

电影:movie_id(PK)(int) in_genre(bridge_table):movie_id(FK)(int),genre_id(int)
SELECT count(*) as common_genre 
FROM(
    // getting genres of first movie
    SELECT in_genre.genre_id
    FROM movie INNER JOIN in_genre ON movie.id = in_genre.movie_id
    WHERE movie.id = 0109830

    INTERSECT

    // getting genres of second movie
    SELECT in_genre.genre_id
    FROM movie INNER JOIN in_genre ON movie.id = in_genre.movie_id
    WHERE movie.id = 1375666
) as genres

【问题讨论】:

两次EXISTS() ? 存在作品感谢您的建议@wildplasser, @lLukStorms 【参考方案1】:

如果你想要这些类型,我会这样做:

SELECT genre_id as common_genre
FROM in_genre ig
WHERE movie_id IN (0109830, 1375666)
GROUP BY genre_id
HAVING COUNT(*) = 2;

如果你想要计数,子查询很简单:

SELECT COUNT(*)
FROM (SELECT genre_id as common_genre
      FROM in_genre ig
      WHERE movie_id IN (0109830, 1375666)
      GROUP BY genre_id
      HAVING COUNT(*) = 2
     ) g;

如果您想了解有关流派的完整信息,那么我建议您exists

select g.*
from genres g
where exists (select 1
              from in_genre ig
              where ig.genre_id = g.genre_id and ig.movie_id = 0109830
             ) and
      exists (select 1
              from in_genre ig
              where ig.genre_id = g.genre_id and ig.movie_id = 1375666
             );

【讨论】:

【参考方案2】:

如果它只需要来自in_genre 的数据,则无需加入movie 表。

您可以使用EXISTS 来查找常见的流派。

SELECT COUNT(DISTINCT genre_id) as common_genre
FROM in_genre ig
WHERE movie_id = 0109830
  AND EXISTS 
  (
      SELECT 1
      FROM in_genre ig2
      WHERE ig2.movie_id = 1375666
        AND ig2.genre_id = ig.genre_id
  )

【讨论】:

以上是关于此 SQL 查询是不是有更有效的替代方法?的主要内容,如果未能解决你的问题,请参考以下文章

Max() 需要很长时间是不是有任何替代方法来编写此查询?

Oracle SQL - 是不是有更有效的方法来组织大量案例语句

如何使用 Spring 的 JDBCTemplate 有效地执行 IN() SQL 查询?

是否有比此查询更具可扩展性的子选择替代方案?

在 SQL Server 中联合所有的替代方案

如何提高子查询的性能或 sql 中子查询的替代方案