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

MySQL에서 각 작성자의 최신 게시물을 효율적으로 검색하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-15 20:10:14487검색

How to Efficiently Retrieve the Latest Post for Each Author in MySQL?

MySQL에서 작성자별 최신 게시물 검색: Before Group By 정렬 대신 JOIN 사용

각 항목에 대한 최신 게시물을 검색하려고 할 때 데이터베이스 작성자의 경우 MySQL에서 GROUP BY 전에 ORDER BY 절을 사용하는 초기 접근 방식은 종종 바람직하지 않은 결과를 낳습니다. 그러나 그룹화하기 전에 하위 쿼리를 사용하여 행을 정렬하는 것이 잠재적인 해결책이 될 수 있습니다.

Order by Before Group By가 문제가 될 수 있는 이유

예제 쿼리를 고려하세요.

SELECT wp_posts.* FROM wp_posts
WHERE wp_posts.post_status='publish'
AND wp_posts.post_type='post'
GROUP BY wp_posts.post_author           
ORDER BY wp_posts.post_date DESC

이 쿼리는 작성자별로 게시물을 그룹화하고 각각의 최신 게시물을 반환하는 것을 목표로 하지만 게시물이 여러 개인 경우 실패할 수 있습니다. 동일한 post_date를 사용합니다. 이러한 경우 각 작성자 그룹 내에서 게시물이 반환되는 순서를 예측할 수 없게 되어 일관되지 않은 결과가 발생하게 됩니다.

하위 쿼리를 사용하여 문제 해결

제안된 방법 이 문제에 대한 해결책은 다음과 같은 하위 쿼리를 활용하는 것입니다.

SELECT wp_posts.* FROM 
(
    SELECT * 
    FROM wp_posts
    ORDER BY wp_posts.post_date DESC
) AS wp_posts
WHERE wp_posts.post_status='publish'
AND wp_posts.post_type='post'
GROUP BY wp_posts.post_author 

이를 사용하여 하위 쿼리에서 게시물은 먼저 post_date를 기준으로 내림차순으로 정렬됩니다. 그런 다음 결과 하위 쿼리 테이블은 기본 쿼리의 소스 역할을 하여 그룹화하기 전에 최신 게시물이 각 작성자 그룹의 맨 위에 배치되도록 합니다.

JOIN을 사용한 대체 접근 방식

작성자별 최신 게시물을 검색하는 또 다른 효과적인 접근 방식은 JOIN 작업을 활용하는 것입니다. 다음 쿼리는 이 방법을 보여줍니다.

SELECT p1.* 
FROM wp_posts p1
INNER JOIN
(
    SELECT max(post_date) MaxPostDate, post_author
    FROM wp_posts
    WHERE post_status='publish'
       AND post_type='post'
    GROUP BY post_author
) p2
  ON p1.post_author = p2.post_author
  AND p1.post_date = p2.MaxPostDate
WHERE p1.post_status='publish'
  AND p1.post_type='post'
order by p1.post_date desc

이 쿼리는 두 단계로 구성됩니다.

  1. 하위 쿼리는 각 작성자의 최대 post_date 및 해당 post_author를 찾습니다.
  2. 기본 쿼리는 post_date 및 post_author 모두에 대한 하위 쿼리 결과와 게시물이 포함된 테이블을 조인하여 각 게시물에 대한 최신 게시물을 효과적으로 검색합니다. 작성자.

결론

그룹화하기 전에 하위 쿼리를 사용하여 행을 정렬하는 것은 작성자별로 최신 게시물을 검색하는 효과적인 솔루션이 될 수 있지만, 접근만 가능합니다. JOIN 연산은 효율적이면서 신뢰할 수 있는 결과를 생성하는 대체 방법을 제공합니다.

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

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