성능 및 디스크 공간 절감을 위한 MySQL Select 쿼리 최적화
실행하는 데 몇 분 정도 걸리는 느린 MySQL 쿼리는 흔히 발생하는 성능 문제입니다. 개발자에 의해. 이 시나리오에서 쿼리는 세 개의 테이블에서 데이터를 검색하여 웹 페이지를 표시합니다. EXPLAIN 명령을 사용하여 조사한 결과, 쿼리가 중간 결과를 디스크에 기록하여 상당한 성능 병목 현상이 발생하는 것으로 나타났습니다.
쿼리를 최적화하기 위해 다음과 같은 포괄적인 접근 방식을 취했습니다.
테이블 구조 분석
쿼리는 세 개의 테이블(poster_data, Poster_categories, Poster_prodcat)을 사용했습니다. Poster_data에는 개별 포스터에 대한 정보가 포함되어 있는 반면, Poster_categories에는 모든 카테고리(예: 영화, 예술)가 나열되어 있습니다. Poster_prodcat에는 포스터 ID와 관련 카테고리가 보관되어 있습니다. 주요 병목 현상은 1,700만 개 이상의 행과 필터링되는 특정 범주에 대한 많은 결과(약 400,000개)가 있는 Poster_prodcat에서 식별되었습니다.
색인 최적화
EXPLAIN 출력에서는 쿼리에 최적의 인덱싱이 부족하여 데이터 액세스가 비효율적이고 실행 속도가 느려지는 것으로 나타났습니다. 가장 큰 문제는 필터링에 사용된 Poster_prodcat.apcatnum 열에 인덱스가 없다는 점이었습니다. 인덱스가 없으면 MySQL 최적화 프로그램이 전체 테이블 스캔을 사용하여 과도한 디스크 I/O와 긴 실행 시간이 발생했습니다.
쿼리 재작성
성능 문제를 해결하려면 문제에서는 보다 효율적인 접근 방식을 사용하여 쿼리가 다시 작성되었습니다.
- 세 테이블은 INNER JOIN 대신 INNER JOIN을 사용하여 조인되었습니다. 덜 효율적인 SELECT *.
- WHERE 절을 단순화하여 하위 쿼리가 필요 없이 원하는 카테고리를 직접 필터링했습니다.
- ORDER BY 절을 쿼리 끝으로 이동하여 대용량 데이터세트의 불필요한 정렬을 방지합니다.
임시 테이블 생성
디스크 공간 사용량 문제를 완화하기 위해 최적화된 쿼리를 추가로 수정하여 중간 결과를 저장하는 임시 테이블을 생성했습니다. 이 접근 방식을 사용하면 쿼리가 디스크에 데이터 쓰기를 우회하여 성능이 크게 향상되었습니다.
추가 최적화
기본 최적화 외에도 몇 가지 추가 조치가 구현되어 더욱 향상되었습니다. 쿼리 성능:
- LIMIT 절을 사용하여 결과 제한: 원래 쿼리에는 제한이 없었으며 잠재적으로 반환될 수 있습니다. 웹 페이지에 필요하지 않은 다수의 결과.
- 결과 캐싱: 임시 테이블은 MEMORY 엔진으로 생성되어 더 빠른 액세스를 위해 데이터를 메모리에 보관했습니다.
결론
인덱싱, 쿼리 구조, 임시 테이블 사용 문제를 해결하여 원래 쿼리를 최적화하여 성능을 향상하고 디스크 공간 사용량을 줄였습니다. 이러한 최적화로 인해 실행 시간이 크게 단축되어 웹페이지 생성 반응성이 훨씬 향상되었습니다.
위 내용은 성능을 향상하고 디스크 공간 사용량을 줄이기 위해 느린 MySQL SELECT 쿼리를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 Docker에서 MySQL 메모리 사용을 최적화합니다. 모니터링 기술 (Docker Stats, Performance Schema, 외부 도구) 및 구성 전략에 대해 설명합니다. 여기에는 Docker 메모리 제한, 스와핑 및 CGroups와 함께 포함됩니다

이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

이 기사에서는 MySQL의 "공유 라이브러리를 열 수 없음"오류를 다룹니다. 이 문제는 MySQL이 필요한 공유 라이브러리 (.so/.dll 파일)를 찾을 수 없음에서 비롯됩니다. 솔루션은 시스템 패키지 M을 통한 라이브러리 설치 확인과 관련이 있습니다.

이 기사는 Linux에 MySQL을 직접 설치하는 것과 Phpmyadmin이없는 Podman 컨테이너 사용을 비교합니다. 각 방법에 대한 설치 단계에 대해 자세히 설명하면서 Podman의 격리, 이식성 및 재현성의 장점을 강조하지만 또한

이 기사는 자체 포함 된 서버리스 관계형 데이터베이스 인 SQLITE에 대한 포괄적 인 개요를 제공합니다. SQLITE의 장점 (단순성, 이식성, 사용 용이성) 및 단점 (동시성 제한, 확장 성 문제)에 대해 자세히 설명합니다. 기음

이 안내서는 Homebrew를 사용하여 MacOS에 여러 MySQL 버전을 설치하고 관리하는 것을 보여줍니다. 홈 브루를 사용하여 설치를 분리하여 갈등을 방지하는 것을 강조합니다. 이 기사에는 설치, 서비스 시작/정지 서비스 및 Best Pra에 대해 자세히 설명합니다

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

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

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

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Dreamweaver Mac版
시각적 웹 개발 도구
