최종 가이드 - 더 나은 SQL 쿼리를 작성하는 방법은 무엇입니까?
역 모델에는 쿼리 작성에 대한 컬렉션 기반 접근 방식과 절차적 접근 방식 간에 차이가 있다는 사실이 암시되어 있습니다.
- 질의에 대한 절차적 접근 방식은 프로그래밍과 매우 유사한 접근 방식입니다. 즉, 수행해야 할 작업과 수행 방법을 시스템에 알려줍니다. 예를 들어 이전 기사의 예와 같이 한 함수를 실행한 후 다른 함수를 호출하여 데이터베이스를 쿼리하거나 루프, 조건 및 사용자 정의 함수(UDF)를 포함하는 논리적 접근 방식을 사용하여 최종 쿼리 결과를 얻습니다. 이런 방식으로 항상 각 계층의 데이터 하위 집합을 요청한다는 것을 알 수 있습니다. 이 접근 방식은 종종 단계별 또는 행별 쿼리라고도 합니다.
- 다른 하나는 수행해야 하는 작업만 지정하면 되는 컬렉션 기반 접근 방식입니다. 이 방법으로 해야 할 일은 쿼리를 통해 얻고자 하는 결과에 대한 조건과 요구 사항을 지정하는 것입니다. 데이터를 검색할 때 쿼리를 구현하는 내부 메커니즘에 주의할 필요가 없습니다. 데이터베이스 엔진은 쿼리를 실행하는 데 가장 적합한 알고리즘과 논리를 결정합니다.
SQL은 집합 기반이므로 이 접근 방식은 절차적 접근 방식보다 더 효율적입니다. 이는 어떤 경우에는 SQL이 코드보다 빠르게 작동할 수 있는 이유를 설명합니다.
세트 기반 쿼리 방법은 데이터 마이닝 분석 업계에서 숙달해야 하는 기술이기도 합니다! 왜냐하면 이 두 가지 방법을 전환하는 데 능숙해야 하기 때문입니다. 쿼리에 절차적 쿼리가 있는 경우 이 부분을 다시 작성해야 하는지 고려해야 합니다.
역방향 모드는 정적이 아닙니다. SQL 개발자가 되기 위한 과정에서 쿼리 역방향 모델을 피하고 쿼리를 다시 작성하는 것은 어려운 작업이 될 수 있습니다. 따라서 보다 구조화된 방식으로 쿼리를 최적화하기 위해 도구를 사용해야 하는 경우가 많습니다.
성능에 대해 생각하려면 보다 체계적인 접근 방식뿐만 아니라 더 심층적인 접근 방식도 필요합니다.
그러나 이 구조적이고 심층적인 접근 방식은 주로 쿼리 계획을 기반으로 합니다. 쿼리 계획은 먼저 "구문 분석 트리"로 구문 분석되고 각 작업에 사용되는 알고리즘과 작업이 조정되는 방식을 정확하게 정의합니다.
쿼리 최적화쿼리를 최적화할 때 최적화 프로그램에서 생성된 계획을 수동으로 검사해야 할 가능성이 높습니다. 이 경우 쿼리 계획을 확인하여 쿼리를 다시 분석해야 합니다.
이러한 쿼리 계획을 익히려면 데이터베이스 관리 시스템에서 제공하는 일부 도구를 사용해야 합니다. 사용할 수 있는 몇 가지 도구는 다음과 같습니다.
- 일부 소프트웨어 패키지에는 쿼리 계획의 그래픽 표현을 생성할 수 있는 도구가 있습니다.
- 다른 도구는 쿼리 계획에 대한 텍스트 설명을 제공할 수 있습니다.
PostgreSQL을 사용하는 경우 다양한 EXPLAIN을 구별할 수 있으며, 계획을 실행하지 않고도 플래너가 쿼리를 실행하는 방법에 대한 설명만 얻을 수 있습니다. 동시에 EXPLAIN ANALYZE는 쿼리를 실행하고 쿼리 계획과 실제 쿼리 계획을 평가하는 분석 보고서를 반환합니다. 일반적으로 실제 실행 계획은 실제로 계획을 실행하며, 평가 실행 계획은 쿼리를 실행하지 않고도 이 문제를 해결할 수 있습니다. 논리적으로 실제 실행 계획에는 쿼리가 실행될 때 실제로 발생한 일에 대한 추가 세부 정보와 통계가 포함되어 있으므로 더 유용합니다.
다음으로 XPLAIN 및 ANALYZE에 대해 자세히 알아보고 이 두 명령을 사용하여 쿼리 계획과 쿼리 성능을 더 자세히 이해하는 방법을 알아봅니다. 이렇게 하려면 one_million 및 half_million이라는 두 테이블을 사용하여 몇 가지 예를 수행해야 합니다.
EXPLAIN을 사용하여 one_million 테이블의 현재 정보를 검색할 수 있습니다. 쿼리를 실행할 때 이 정보를 첫 번째 위치에 넣어야 하며, 실행이 완료된 후 쿼리 계획으로 반환됩니다.
으아악위 예에서 쿼리 비용은 0.00..18584.82, 행 수는 1025082, 열 너비는 36임을 알 수 있습니다.
동시에 ANALYZE를 사용하여 통계 정보를 업데이트할 수도 있습니다.
으아악EXLAIN 및 ANALYZE 외에도 EXPLAIN ANALYZE를 사용하여 실제 실행 시간을 검색할 수도 있습니다.
으아악EXPLAIN ANALYZE 사용의 단점은 실제로 쿼리를 실행해야 한다는 점인데, 이는 주목할 가치가 있습니다!
지금까지 본 모든 알고리즘은 순차적 스캔 또는 전체 테이블 스캔입니다. 이는 데이터베이스에서 스캔하는 방법으로, 스캔된 테이블의 각 행을 순차적(직렬) 순서로 읽고 각 열을 확인합니다. 조건에 맞는지 확인해보세요. 성능 측면에서 순차 스캔은 테이블 전체를 스캔해야 하기 때문에 최선의 실행 계획은 아닙니다. 그러나 느린 디스크를 사용하면 순차 읽기도 빨라집니다.
다른 알고리즘의 몇 가지 예가 있습니다:
으아악쿼리 최적화 프로그램이 Hash Join을 선택한 것을 볼 수 있습니다. 쿼리의 시간 복잡도를 평가하기 위해 이 작업을 사용해야 하므로 이 작업을 기억하세요. 위 예에서는 half_million.counter 인덱스가 없다는 것을 확인했습니다. 아래 예에서 인덱스를 추가할 수 있습니다.
으아악쿼리 최적화 프로그램은 인덱스를 생성하여 인덱스 스캔 시 병합 조인을 찾는 방법을 결정했습니다.
인덱스 스캔과 전체 테이블 스캔(순차 스캔)의 차이점에 유의하세요. 후자("테이블 스캔"이라고도 함)는 모든 데이터를 스캔하거나 모든 페이지를 인덱싱하여 적합한 결과를 찾는 반면, 전자는 테이블의 각 행만 스캔합니다. 탁자.
튜토리얼의 두 번째 부분이 여기에 소개됩니다. "더 나은 SQL 쿼리를 작성하는 방법" 시리즈의 마지막 기사가 이어질 예정이므로 계속 지켜봐 주시기 바랍니다.
재인쇄 출처를 밝혀주세요: Grape City Control
위 내용은 최종 가이드 - 더 나은 SQL 쿼리를 작성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











Centos와 Ubuntu의 주요 차이점은 다음과 같습니다. Origin (Centos는 Red Hat, Enterprise의 경우, Ubuntu는 Debian에서 시작하여 개인의 경우), 패키지 관리 (Centos는 안정성에 중점을 둡니다. Ubuntu는 APT를 사용하여 APT를 사용합니다), 지원주기 (Ubuntu는 5 년 동안 LTS 지원을 제공합니다), 커뮤니티에 중점을 둔다 (Centos Conciors on ubuntu). 튜토리얼 및 문서), 사용 (Centos는 서버에 편향되어 있으며 Ubuntu는 서버 및 데스크탑에 적합), 다른 차이점에는 설치 단순성 (Centos는 얇음)이 포함됩니다.

CentOS 설치 단계 : ISO 이미지를 다운로드하고 부팅 가능한 미디어를 실행하십시오. 부팅하고 설치 소스를 선택하십시오. 언어 및 키보드 레이아웃을 선택하십시오. 네트워크 구성; 하드 디스크를 분할; 시스템 시계를 설정하십시오. 루트 사용자를 만듭니다. 소프트웨어 패키지를 선택하십시오. 설치를 시작하십시오. 설치가 완료된 후 하드 디스크에서 다시 시작하고 부팅하십시오.

Centos는 중단되었으며 대안은 다음과 같습니다. 1. Rocky Linux (Best Compatibility); 2. Almalinux (Centos와 호환); 3. Ubuntu 서버 (구성 필수); 4. Red Hat Enterprise Linux (상업용 버전, 유료 라이센스); 5. Oracle Linux (Centos 및 Rhel과 호환). 마이그레이션시 고려 사항은 호환성, 가용성, 지원, 비용 및 커뮤니티 지원입니다.

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).

Docker는 Linux 커널 기능을 사용하여 효율적이고 고립 된 응용 프로그램 실행 환경을 제공합니다. 작동 원리는 다음과 같습니다. 1. 거울은 읽기 전용 템플릿으로 사용되며, 여기에는 응용 프로그램을 실행하는 데 필요한 모든 것을 포함합니다. 2. Union 파일 시스템 (Unionfs)은 여러 파일 시스템을 스택하고 차이점 만 저장하고 공간을 절약하고 속도를 높입니다. 3. 데몬은 거울과 컨테이너를 관리하고 클라이언트는 상호 작용을 위해 사용합니다. 4. 네임 스페이스 및 CGroup은 컨테이너 격리 및 자원 제한을 구현합니다. 5. 다중 네트워크 모드는 컨테이너 상호 연결을 지원합니다. 이러한 핵심 개념을 이해 함으로써만 Docker를 더 잘 활용할 수 있습니다.

Centos가 중단 된 후 사용자는 다음과 같은 조치를 취할 수 있습니다. Almalinux, Rocky Linux 및 Centos 스트림과 같은 호환되는 분포를 선택하십시오. Red Hat Enterprise Linux, Oracle Linux와 같은 상업 분포로 마이그레이션합니다. Centos 9 Stream : 롤링 분포로 업그레이드하여 최신 기술을 제공합니다. Ubuntu, Debian과 같은 다른 Linux 배포판을 선택하십시오. 컨테이너, 가상 머신 또는 클라우드 플랫폼과 같은 다른 옵션을 평가하십시오.

실패한 Docker 이미지 빌드에 대한 문제 해결 단계 : Dockerfile 구문 및 종속성 버전을 확인하십시오. 빌드 컨텍스트에 필요한 소스 코드 및 종속성이 포함되어 있는지 확인하십시오. 오류 세부 사항에 대한 빌드 로그를보십시오. -표적 옵션을 사용하여 계층 적 단계를 구축하여 실패 지점을 식별하십시오. 최신 버전의 Docker Engine을 사용하십시오. -t [image-name] : 디버그 모드로 이미지를 빌드하여 문제를 디버깅하십시오. 디스크 공간을 확인하고 충분한 지 확인하십시오. 빌드 프로세스에 대한 간섭을 방지하기 위해 Selinux를 비활성화하십시오. 커뮤니티 플랫폼에 도움을 요청하고 Dockerfiles를 제공하며보다 구체적인 제안을 위해 로그 설명을 구축하십시오.

대 코드 시스템 요구 사항 : 운영 체제 : Windows 10 이상, MacOS 10.12 이상, Linux 배포 프로세서 : 최소 1.6GHz, 권장 2.0GHz 이상의 메모리 : 최소 512MB, 권장 4GB 이상의 저장 공간 : 최소 250MB, 권장 1GB 및 기타 요구 사항 : 안정 네트워크 연결, Xorg/Wayland (LINUX)
