>데이터 베이스 >MySQL 튜토리얼 >하위 쿼리 없이 MySQL에서 각 작성자의 최신 게시물을 효율적으로 가져오는 방법은 무엇입니까?

하위 쿼리 없이 MySQL에서 각 작성자의 최신 게시물을 효율적으로 가져오는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-29 02:22:10384검색

How to Efficiently Get the Latest Post for Each Author in MySQL Without Subqueries?

MySQL Order By Before Group By: 대체 접근 방식

MySQL에서는 그룹화 전 행 정렬이 어려울 수 있으며, 특히 원하는 순서가 다음과 같은 경우에는 더욱 그렇습니다. 후속 그룹에서는 보장되지 않습니다. 하위 쿼리를 사용하는 것이 일반적인 솔루션이지만 항상 가장 최적의 접근 방식은 아닐 수 있습니다.

제시된 시나리오의 목표는 wp_posts 테이블에서 각 작성자의 최신 게시물을 검색하는 것입니다. "현재 허용되는 답변"으로 설명된 쿼리를 포함하여 제공된 쿼리가 예상한 결과를 일관되게 제공하지 못합니다.

하위 쿼리에 의존하지 않고 이 문제를 해결하는 대체 솔루션은 창 기능 조합을 활용하는 것입니다. 및 셀프 조인:

WITH LatestPostsPerAuthor AS (
    SELECT *, ROW_NUMBER() OVER (PARTITION BY post_author ORDER BY post_date DESC) AS rn
    FROM wp_posts
    WHERE post_status='publish'
    AND post_type='post'
)
SELECT a.*
FROM LatestPostsPerAuthor a
JOIN LatestPostsPerAuthor b ON a.rn = b.rn AND a.post_author = b.post_author
GROUP BY a.post_author
ORDER BY a.post_date DESC;

이 쿼리는 ROW_NUMBER() 창 함수를 사용하여 각 작성자 그룹 내의 게시일을 기준으로 게시물에 순위를 할당합니다. 그러면 셀프 조인을 통해 순위가 가장 높은 행(예: 최신 게시물)만 그룹화 및 정렬을 위해 유지됩니다.

이 접근 방식을 사용하면 작업에 대한 오버헤드 없이 원하는 결과를 얻을 수 있습니다. 하위 쿼리를 사용하여 주어진 시나리오에 대해 정확하고 일관된 결과를 제공합니다.

위 내용은 하위 쿼리 없이 MySQL에서 각 작성자의 최신 게시물을 효율적으로 가져오는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.