SQL 효율성 최적화 연구
2016년 8월 상하이 MOORACLE 컨퍼런스에서 Chen Hongyi(Old K)님이 공유한 사례입니다. 병합 SQL을 plsql에 다시 작성하여 실행 효율성이 크게 향상되었습니다. Tiger Liu는 이 사례를 처음 봤을 때 실행 계획에 표시된 각 테이블의 실제 레코드 수를 눈치채지 못했고 plsql을 다시 작성하는 방법이 분석 함수를 작성하는 방법보다 더 효율적이라고 생각하지도 않았습니다. 첸 선생님과 여러 번의 이메일 토론을 하고 나서야 실행 계획을 자세히 살펴보았습니다.
원본 SQL은 다음과 같습니다. 를 사용하여 t_customer c에 병합(
a.cstno, t_trade a의 금액을 선택하세요.
(t_trade에서 cstno,max(trade_date) trade_date를 선택하세요
그룹 by cstno)b
여기서 a.cstno = b.cstno 및 a.trade_date=b.trade_date
) 음
on(c.cstno = m.cstno)
일치하면 그때
업데이트 세트 c.amount = m.amount;
이 SQL은 병합 연산을 통해 사용자 거래 내역 테이블(t_trade)의 최근 소비 금액을 사용자 정보 테이블(t_customer)의 소비 금액 필드로 업데이트하는 SQL입니다.
실행 계획:
타이거 리우 참고:
분석 함수 작성 방법을 익히기 전, SQL의 빨간색 부분은 그룹별로 다른 필드 정보를 작성하는 일반적인 방법이며, 이는 이 SQL의 실행 효율성이 떨어지는 근본적인 이유이기도 합니다.
원래 SQL에는 또 다른 숨겨진 위험이 있습니다. 즉, t_trade의 특정 cstno에 해당하는 최대 trade_date가 반복되면 이 SQL은 ORA-30926 오류를 보고하고 실행될 수 없습니다.
실행 계획(두 테이블의 실제 데이터 볼륨 정보)을 주의 깊게 살펴보지 않으면 이러한 종류의 SQL에 대한 일반적인 최적화 방법은 분석 함수를 사용하여 다시 작성하는 것입니다.
다시 쓰기 방법 1: 를 사용하여 t_customer c에 병합(
a.cstno,a.amount from
을 선택하세요.(거래 날짜,cstno,금액,
을 선택하세요.row_number()over(partition by cstno order by trade_date desc) RNO from t_trade)a
RNO=1
) 음
on(c.cstno = m.cstno)
일치하면 그때
업데이트 세트 c.amount = m.amount;
이 재작성 방법은 원본 SQL보다 훨씬 효율적이며 특정 cstno에 해당하는 최대 trade_date에 대해 반복 오류가 발생하는 문제가 없습니다.
하지만 Chen 선생님은 분석 함수의 재작성 방법을 사용하지 않고, 대신 두 테이블 간의 데이터 양의 큰 차이를 기반으로 SQL을 보다 효율적인 plsql로 재작성했습니다.
다시 쓰는 방법 2:선언
잔액수;
시작
for v in (t_customer에서 * 선택)
루프
vamount에서 금액 선택
(t_trade에서 금액 선택, 여기서 cstno=v.cstno trade_date desc로 주문)
rownum
t_customer 설정 금액 업데이트 = vmount 여기서 cstno=v.cstno;
끝 루프
커밋;
끝;
/
원래 SQL 실행 계획에 따르면, t_customer 테이블의 레코드 수는 1,000개를 넘을 정도로 비교적 적은 반면, t_trade 테이블의 레코드 수는 1:10,000의 비율로 1,000만 개라는 것을 알고 있습니다. 이것이 실제 데이터인지 테스트 데이터인지 알 수 있는 것은 사용자가 1,000명이 넘고 사용자가 평균 10,000개의 소비 내역을 가지고 있어 실제 데이터처럼 보이지 않습니다.
두 테이블 간의 데이터가 상당히 다른 특별한 경우에는 plsql 작성 방법이 분석 함수 작성 방법보다 실제로 더 효율적입니다. 이 재작성은 매우 영리합니다.
이 두 가지 재작성의 장점과 단점을 분석해 보겠습니다.1. plsql의 재작성 방법은 t_customer 테이블이 상대적으로 작고 t_customer 및 t_trade 테이블의 레코드 수 비율이 상대적으로 큰 상황에 적합합니다. . 이 예에서 t_customer 테이블의 레코드 수가 100,000개라면 분석 함수를 작성하는 방법은 plsql을 작성하는 방법보다 수십~수백 배 빠릅니다.
3. plsql을 다시 작성하려면 t_trade 테이블의 cstno + trade_date 두 필드에 대한 공동 인덱스가 있어야 합니다. 분석 함수를 다시 작성하는 데에는 인덱스 지원이 필요하지 않습니다.
4. t_trade와 같이 수천만 개의 레코드가 있는 테이블의 경우 분석 기능을 사용하는 작성 방법은 병렬성을 켜면 속도를 높일 수 있습니다. plsql을 다시 작성할 때 효율성을 높이려면 먼저 t_customer 테이블을 cstno로 그룹화해야 합니다. 여러 세션을 사용하여 동시에 실행합니다.
첸 선생님의 plsql이 단일 SQL로 구현될 수 있는지 확인해 보겠습니다. SQL 코드는 다음과 같습니다.
를 사용하여 t_customer c에 병합
(tc.cstno를 선택하세요,
(금액선택
t_trade td1에서
여기서 td1.cstno=tc.cstno 및 td1.trade_date = (t_trade td2에서 max(trade_date) 선택, 여기서 tc.cstno = td2.cstno) 및 rownum=1) 금액
from t_customer tc
) 음
on(c.cstno = m.cstno)
일치하면 그때
업데이트 세트 c.amount = m.amount;
실행 계획은 대략 다음과 같습니다.
이 작성 방법도 t_trade 테이블에 cstno+trade_date 공동 인덱스(IDX_T_TRADE)가 있어야 하며, T_customer 테이블의 데이터 양은 T_trade보다 훨씬 적습니다.
실행 계획에 따르면 이 SQL의 실행 효율성은 plsql 작성 효율성과 비슷해야 합니다.
요약:SQL 최적화는 비효율적인 SQL 작성을 방지하는 것 외에도 주로 테이블의 데이터 볼륨 및 데이터 분포에 따라 달라집니다. plsql의 재작성 방법은 일부 데이터의 경우 더 높은 효율성을 보여줍니다. 효율성은 원래 SQL만큼 좋지 않을 수 있습니다. 그러나 최적화 아이디어는 배울 가치가 있습니다.
분석 기능이 다시 작성되는 방식은 데이터가 어떻게 분산되어 있든 원래 SQL보다 더 효율적이고 다재다능할 것입니다.
이 예제를 다시 작성하기 전에도 SQL을 사용하는 개발자와 DBA가 많았을 것입니다. 분석 기능을 사용하는 방법을 이해한 후에는 원래 SQL을 작성하는 비효율적인 방법을 완전히 버려야 합니다.
마지막 plsql은 단일 SQL로 다시 작성되었습니다. 로직이 복잡하고 이해하기 어려울 것 같습니다. 일반적으로 이러한 다시 작성은 사용되지 않습니다.
동일한 문장이지만 최적화에 대한 명확한 공식은 없습니다. 최적화 프로그램은 죽었지만 인간의 두뇌는 살아 있습니다. 원칙을 숙지해야만 SQL 실행 효율성이 더욱 높아질 수 있습니다.
위 내용은 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)

뜨거운 주제











DeepSeek은 웹 버전과 공식 웹 사이트의 두 가지 액세스 방법을 제공하는 강력한 지능형 검색 및 분석 도구입니다. 웹 버전은 편리하고 효율적이며 설치없이 사용할 수 있습니다. 개인이든 회사 사용자이든, DeepSeek를 통해 대규모 데이터를 쉽게 얻고 분석하여 업무 효율성을 향상시키고 의사 결정을 지원하며 혁신을 촉진 할 수 있습니다.

Docker 컨테이너를 사용하여 사전 컴파일 된 패키지 (Windows 사용자의 경우)를 사용하여 소스 (숙련 된 개발자)를 컴파일하는 것을 포함하여 DeepSeek를 설치하는 방법에는 여러 가지가 있습니다. 공식 문서는 신중하게 문서를 작성하고 불필요한 문제를 피하기 위해 완전히 준비합니다.

Bitget은 스팟 거래, 계약 거래 및 파생 상품을 포함한 다양한 거래 서비스를 제공하는 Cryptocurrency 교환입니다. 2018 년에 설립 된이 교환은 싱가포르에 본사를두고 있으며 사용자에게 안전하고 안정적인 거래 플랫폼을 제공하기 위해 노력하고 있습니다. Bitget은 BTC/USDT, ETH/USDT 및 XRP/USDT를 포함한 다양한 거래 쌍을 제공합니다. 또한 Exchange는 보안 및 유동성으로 유명하며 프리미엄 주문 유형, 레버리지 거래 및 24/7 고객 지원과 같은 다양한 기능을 제공합니다.

세계 최고의 디지털 자산 거래소 인 Ouyi Okx는 이제 안전하고 편리한 거래 경험을 제공하기 위해 공식 설치 패키지를 시작했습니다. OUYI의 OKX 설치 패키지는 브라우저를 통해 액세스 할 필요가 없습니다. 설치 프로세스는 간단하고 이해하기 쉽습니다. 사용자는 최신 버전의 설치 패키지를 다운로드하고 설치를 단계별로 완료하면됩니다.

Gate.io는 사용자가 설치 패키지를 다운로드하여 장치에 설치하여 사용할 수있는 인기있는 cryptocurrency 교환입니다. 설치 패키지를 얻는 단계는 다음과 같습니다. Gate.io의 공식 웹 사이트를 방문하고 "다운로드"를 클릭하고 해당 운영 체제 (Windows, Mac 또는 Linux)를 선택하고 컴퓨터에 설치 패키지를 다운로드하십시오. 설치 중에 항 바이러스 소프트웨어 또는 방화벽을 일시적으로 비활성화하여 원활한 설치를 보장하는 것이 좋습니다. 완료 후 사용자는 GATE.IO 계정을 만들려면 사용을 시작해야합니다.

OKX라고도하는 Ouyi는 세계 최고의 암호 화폐 거래 플랫폼입니다. 이 기사는 OUYI의 공식 설치 패키지 용 다운로드 포털을 제공하여 사용자가 다른 장치에 OUYI 클라이언트를 설치할 수 있도록합니다. 이 설치 패키지는 Windows, Mac, Android 및 iOS 시스템을 지원합니다. 설치가 완료되면 사용자는 OUYI 계정에 등록하거나 로그인하고 암호 화폐 거래를 시작하며 플랫폼에서 제공하는 기타 서비스를 즐길 수 있습니다.

Gate.io는 광범위한 토큰 선택, 낮은 거래 수수료 및 사용자 친화적 인 인터페이스로 유명한 호평을받는 암호 화폐 거래 플랫폼입니다. Gate.io는 고급 보안 기능과 우수한 고객 서비스를 통해 트레이더에게 신뢰할 수 있고 편리한 암호 화폐 거래 환경을 제공합니다. Gate.io에 가입하려면 제공된 링크를 클릭하여 공식 등록 설치 패키지를 다운로드하여 Cryptocurrency 거래 여정을 시작하십시오.

이 튜토리얼은 기존 Apache 서버와 함께 Ubuntu 시스템에 Nginx 및 Phpmyadmin을 설치하고 구성하는 것을 안내합니다. 우리는 Nginx 설정, Apache와의 잠재적 포트 충돌 해결, Mariadb 설치를 다루겠습니다.
