> 데이터 베이스 > MySQL 튜토리얼 > MySQL 테이블에서 오름차순으로 마지막 N 행을 안정적으로 선택하는 방법은 무엇입니까?

MySQL 테이블에서 오름차순으로 마지막 N 행을 안정적으로 선택하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-04 02:29:12
원래의
584명이 탐색했습니다.

How to Reliably Select the Last N Rows in Ascending Order from a MySQL Table?

MySQL에서 마지막 N 행 선택

MySQL 데이터베이스에서 마지막 N 행 선택은 다양한 방법을 사용하여 간단한 작업이 될 수 있습니다. 그러나 오름차순으로 정렬된 기본 키 열을 처리할 때 기존 접근 방식에는 한계가 있을 수 있습니다. 이 글의 목표는 테이블 내의 레코드를 조작하고 제거할 수 있도록 하여 이 문제에 대한 신뢰할 수 있는 솔루션을 제공하는 것입니다.

문제:

원래 목표는 검색하는 것입니다. 기본 키 열 ID를 기준으로 오름차순으로 정렬된 테이블의 마지막 50개 행입니다. 그러나 초기 시도에서는 두 가지 약점이 드러났습니다.

  1. ORDER BY id DESC를 사용하여 행을 내림차순으로 정렬하면 LIMIT 50을 사용할 때 원하는 ASC 순서를 유지하지 못합니다.
  2. 다음 쿼리에 의존합니다. 최대 ID에서 고정된 값을 뺍니다(예: id > (SELECT MAX(id) FROM chat) - 50) 행이 조작되면 신뢰성이 떨어집니다.

해결책:

이러한 문제를 극복하기 위해 보다 강력한 접근 방식은 다음을 사용합니다. 하위 쿼리:

SELECT * FROM
(
 SELECT * FROM table ORDER BY id DESC LIMIT 50
) AS sub
ORDER BY id ASC;
로그인 후 복사

설명:

  • 하위 쿼리((SELECT * FROM table ORDER BY id DESC LIMIT 50))는 내림차순을 유지하면서 테이블의 마지막 50개 행을 삭제합니다.
  • 외부 쿼리(SELECT * FROM ...)는 하위 쿼리를 래핑하고 이전 정렬을 재정의하고 ID를 기준으로 오름차순으로 행을 재정렬하는 새로운 ORDER BY 절을 도입합니다.

이 접근 방식 기존 방법의 한계를 효과적으로 해결합니다. 다음이 가능합니다.

  • 조작이나 삭제에 관계없이 ASC 순서로 마지막 N 행 검색
  • 행 추가 또는 제거와 같은 테이블 변경 사항 처리 , 쿼리의 정확성에는 영향을 주지 않습니다.

위 내용은 MySQL 테이블에서 오름차순으로 마지막 N 행을 안정적으로 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿