관계형 데이터베이스에서 그룹당 최대값이 있는 행을 효율적으로 검색하려면 어떻게 해야 합니까?
관계형 데이터베이스의 그룹 내에서 효율적으로 최대값 찾기
관계형 데이터베이스 내에서 그룹 무결성을 유지하면서 특정 열의 최대값이 포함된 행을 추출하는 것은 복잡할 수 있습니다. 이 문서에서는 쿼리 효율성을 우선시하면서 각 고유 ID에 대해 가장 높은 반올림 번호가 있는 행을 검색하는 문제를 다룹니다.
하위 쿼리를 사용하는 한 가지 방법은 다음과 같습니다.
SELECT * FROM (SELECT id, round, CASE WHEN (MAX(round) OVER (PARTITION BY id)) = round THEN score ELSE NULL END score FROM SCORES where id in (1,2,3) ) scorevals WHERE scorevals.round is not null;
그러나 이 접근 방식은 후처리 필터링 단계로 인해 비효율적입니다.
성능 향상을 위해 창 기능 사용을 고려해 보세요.
SELECT DISTINCT id ,max(round) OVER (PARTITION BY id) AS round ,first_value(score) OVER (PARTITION BY id ORDER BY round DESC) AS score FROM SCORES WHERE id IN (1,2,3) ORDER BY id;
이 쿼리는 창 기능을 사용하여 각 ID의 최대 라운드를 결정한 다음 해당 점수를 검색합니다. DISTINCT
키워드는 ID당 단일 행을 보장합니다.
동일한 창 기능을 두 번 사용하는 잠재적으로 더 빠른 대안:
SELECT DISTINCT id ,first_value(round) OVER (PARTITION BY id ORDER BY round DESC) AS round ,first_value(score) OVER (PARTITION BY id ORDER BY round DESC) AS score FROM SCORES WHERE id IN (1,2,3) ORDER BY id;
두 가지 최적화 솔루션 모두 불필요한 필터링을 방지하여 하위 쿼리 접근 방식에 비해 쿼리 실행 시간이 더 빠릅니다.
위 내용은 관계형 데이터베이스에서 그룹당 최대값이 있는 행을 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?
