찾다
데이터 베이스MySQL 튜토리얼MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해

이 글은 MySQL의 고급 연구로서 조인 연결의 원리와 조인의 세 가지 알고리즘을 자세히 소개합니다.

MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해

여러 테이블을 쿼리할 때 조인을 사용하는 경우가 많습니다. 실제로 조인의 효율성이 좋지 않으므로 사용을 피해야 합니다. MySQL은 각 테이블 간의 순환 매칭만 지원합니다. 조인 알고리즘인 Nested-Loop Join에는 실제로 조인의 실행 효율성을 향상시키는 다양한 변형 알고리즘이 있습니다. [관련 권장사항: mysql 동영상 튜토리얼]

1. Simple Nested-Loop Join(Simple Nested Loop Join)

루프의 첫 번째 테이블에서 가져온 NLJ(Simple Nested-Loop Join) 알고리즘 한 행 읽기 일관성을 위해 데이터와 일치하는 중첩 루프에 각 행을 전달합니다. 예를 들어, Driving 테이블 User와 Driven 테이블 UserInfo의 SQL은 select * from User u left Join User_info info on u.id = info.user_id입니다. 루프 의사 코드의 논리는 select * from User u left join User_info info on u.id = info.user_id,其实就是我们常用的for循环,伪代码的逻辑应该是

for(User u:Users){
    for(UserInfo info:UserInfos){
        if(u.id == info.userId){
            // 得到匹配数据
        }
    }
}

简单粗暴的算法,每次从User表中取出一条数据,然后扫描User_info中的所有记录匹配,最后合并数据返回。

假如驱动表User有10条数据,被驱动表UserInfo也有10条数据,那么实际上驱动表User会被扫描10次,而被驱动表会被扫描10*10=100次(每扫描一次驱动表,就会扫描全部的被驱动表),这种效率是很低的,对数据库的开销比较大,尤其是被驱动表。每一次扫描其实就是从硬盘中读取数据加载到内存中,也就是一次IO,目前IO是最大的瓶颈

MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해

2. Index Nested-Loop Join(索引嵌套循环连接)

索引嵌套循环是使用索引减少扫描的次数来提高效率的,所以要求非驱动表上必须有索引才行。

在查询的时候,驱动表(User) 会根据关联字段的索引进行查询,当索引上找到符合的值,才会进行回表查询。如果非驱动表(User_info)的关联字段(user_id)是主键的话,查询效率会非常高(主键索引结构的叶子结点包含了完整的行数据(InnoDB)),如果不是主键,每次匹配到索引后都需要进行一次回表查询(根据二级索引(非主键索引)的主键ID进行回表查询),性能肯定弱于主键的查询。

MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해

上图中的索引查询之后不一定会回表,什么情况下会回表,这个要看索引查询到的字段能不能满足查询需要的字段,具体可以参考之前的文章:你需要知道的一些索引基础知识 和 B+树的索引知识

3. Block Nested-Loop Join(缓存块嵌套循环连接)

如果存在索引,那么会使用index的方式进行join,如果join的列没有索引,被驱动表要扫描的次数太多了,每次访问被驱动表,其表中的记录都会被加载到内存中,然后再从驱动表中取一条与其匹配,匹配结束后清除内存,然后再从驱动表中加载一条记录 然后把被驱动表的记录在加载到内存匹配,这样周而复始,大大增加了IO的次数。为了减少被驱动表的IO次数,就出现了Block Nested-Loop Join的方式。

不再是逐条获取驱动表的数据,而是一块一块的获取,引入了join buffer缓冲区,将驱动表join相关的部分数据列(大小是join buffer的限制)缓存到join buffer中,然后全表扫描被驱动表,被驱动表的每一条记录一次性和join buffer中的所有驱动表记录进行匹配(内存中操作),将简单嵌套循环中的多次比较合并成一次,降低了非驱动表的访问频率。

MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해

驱动表能不能一次加载完,要看join buffer能不能存储所有的数据,默认情况下join_buffer_size=256k,查询的时候Join Buffer 会缓存所有参与查询的列而不是只有join的列,在一个有N个join关联的sql中会分配N-1个join buffer。所以查询的时候尽量减少不必要的字段,可以让join buffer中可以存放更多的列。

可以调整join_buffer_size的缓存大小show variables like '%join_buffer%'rrreee

간단하고 조잡한 알고리즘입니다. User 테이블에서 데이터 조각을 가져올 때마다 User_info의 모든 레코드가 일치하는지 검사하고 마지막으로 데이터가 병합됩니다. 그리고 돌아왔다.

MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해드라이버 테이블 User에 10개의 데이터가 있고, 구동 테이블 UserInfo에도 10개의 데이터가 있는 경우, 드라이버 테이블 User는 실제로 10번 스캔되고, 구동 테이블은 10*10=100번 스캔됩니다. (드라이버가 테이블을 스캔할 때마다 모든 구동 테이블이 스캔됩니다.) 이 효율성은 매우 낮으며 데이터베이스, 특히 구동 테이블의 오버헤드가 상대적으로 큽니다.

각 스캔은 실제로 하드 디스크에서 데이터를 읽고 이를 메모리에 로드하는 것이며, 이는 현재 IO가 가장 큰 병목 현상입니다🎜🎜🎜MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해🎜🎜🎜🎜2. 인덱스 중첩 루프 조인(인덱스 중첩 루프 조인)🎜🎜🎜🎜index 중첩 루프 집합은 인덱스를 사용하여 검색 횟수를 줄여 효율성을 향상시키므로 비구동 테이블에는 인덱스가 있어야 합니다. 🎜🎜쿼리 시 드라이버 테이블(사용자)은 관련 필드의 인덱스를 기반으로 쿼리하고, 인덱스에서 일치하는 값을 찾으면 테이블 쿼리를 수행합니다. 비구동 테이블(User_info)의 관련 필드(user_id)가 기본 키인 경우 쿼리 효율성이 매우 높습니다(기본 키 인덱스 구조의 리프 노드에 완전한 행 데이터(InnoDB)가 포함되어 있음). 기본키가 아닌 경우 매번 인덱스가 일치하게 되는데 마지막으로 테이블 반환 쿼리(보조 인덱스(비기본키 인덱스)의 기본키 ID를 기반으로 한 테이블 반환 쿼리)가 필요하며 성능은 확실히 약하다. 기본 키 쿼리보다 🎜🎜MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해🎜🎜위로 그림의 인덱스 쿼리는 어떤 상황에서 테이블을 반환하지 않을 수 있습니다. 이는 인덱스에서 쿼리한 필드가 쿼리에서 요구하는 필드를 충족할 수 있는지 여부에 따라 다릅니다. : 🎜알아야 할 인덱스 기본 사항 B+ 트리에 대한 지식 및 인덱스 지식 🎜🎜🎜🎜🎜3. Block Nested-Loop Join (캐시 블록 중첩 루프 연결) 🎜🎜🎜🎜인덱스가 있으면 인덱스 방법은 조인 열에 인덱스가 없으면 구동 테이블에 액세스할 때마다 테이블의 레코드가 메모리에 로드된 다음 레코드를 너무 많이 스캔해야 합니다. 일치를 위해 드라이버 테이블에서 가져와 메모리를 비운 다음 드라이버 테이블에서 레코드를 로드한 다음 일치를 위해 구동되는 테이블의 레코드를 메모리에 로드하는 과정이 반복됩니다. 다시 말하면 IO 수가 크게 늘어납니다. 구동 테이블의 IO 수를 줄이기 위해 Block Nested-Loop Join 방법이 등장했습니다. 🎜🎜더 이상 드라이버 테이블의 데이터를 하나씩 가져오는 것이 아니라 하나씩 가져옵니다. 드라이버 테이블의 조인과 관련된 일부 데이터 열을 캐시하기 위해 조인 버퍼가 도입되었습니다. (크기는 조인의 한계입니다.) 버퍼)를 조인 버퍼에 넣은 다음 구동 테이블의 전체 테이블 스캔, 구동 테이블의 각 레코드를 조인 버퍼의 모든 구동 테이블 레코드와 동시에 일치(메모리 내 작업), 간단한 중첩 루프에서 다중 비교 드라이버 테이블에 액세스하는 빈도를 줄여 비용을 절감합니다. 🎜🎜MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해🎜🎜드라이버 테이블을 한 번에 로드할 수 있는지 여부는 조인 버퍼가 모든 데이터를 저장할 수 있는지 여부에 따라 다릅니다. 기본적으로 join_buffer_size=256k, 쿼리 시 조인 버퍼는 대신 쿼리에 참여하는 모든 열을 캐시합니다. N개의 조인 연관이 있는 SQL에서는 조인 열만 N-1개의 조인 버퍼가 할당됩니다. 따라서 쿼리 시 불필요한 필드를 줄여서 조인 버퍼에 더 많은 컬럼을 저장할 수 있도록 노력하세요. 🎜🎜join_buffer_size '%join_buffer%'와 같은 변수 표시의 캐시 크기를 조정할 수 있습니다. 이 값은 실제 상황에 따라 변경될 수 있습니다. 🎜🎜🎜🎜

Block Nested-Loop Join 알고리즘을 사용하려면 기본적으로 켜져 있는 옵티마이저 관리 구성 block_nested_loop의 Optimizer_switch 설정을 on으로 켜야 합니다. show variables like '%optimizer_switch%' 查看block_nested_loop 상태를 통해 이용 가능합니다.

MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해

위의 세 가지 알고리즘을 이해하면 실제로 실제 작업에서는 인덱스를 잘 활용할 수 있다면 좋을 것입니다. 그렇지 않으면 쿼리 효율성을 제공하기 위해 인덱스를 잘 사용해야 합니다.

원본 주소: https://juejin.cn/post/7014105037517357093

저자: Mr. Ji

프로그래밍 관련 지식을 더 알고 싶으시면 프로그래밍 입문을 방문해 주세요! !

위 내용은 MySQL 고급 학습: 조인의 세 가지 알고리즘에 대한 심층적인 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 掘金--纪先生에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
MySQL의 장소 : 데이터베이스 및 프로그래밍MySQL의 장소 : 데이터베이스 및 프로그래밍Apr 13, 2025 am 12:18 AM

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL : 소기업에서 대기업에 이르기까지MySQL : 소기업에서 대기업에 이르기까지Apr 13, 2025 am 12:17 AM

MySQL은 소규모 및 대기업에 적합합니다. 1) 소기업은 고객 정보 저장과 같은 기본 데이터 관리에 MySQL을 사용할 수 있습니다. 2) 대기업은 MySQL을 사용하여 대규모 데이터 및 복잡한 비즈니스 로직을 처리하여 쿼리 성능 및 트랜잭션 처리를 최적화 할 수 있습니다.

Phantom은 무엇을 읽고, Innodb는 어떻게 그들을 막을 수 있습니까 (다음 키 잠금)?Phantom은 무엇을 읽고, Innodb는 어떻게 그들을 막을 수 있습니까 (다음 키 잠금)?Apr 13, 2025 am 12:16 AM

InnoDB는 팬텀 읽기를 차세대 점화 메커니즘을 통해 효과적으로 방지합니다. 1) Next-Keylocking은 Row Lock과 Gap Lock을 결합하여 레코드와 간격을 잠그기 위해 새로운 레코드가 삽입되지 않도록합니다. 2) 실제 응용 분야에서 쿼리를 최적화하고 격리 수준을 조정함으로써 잠금 경쟁을 줄이고 동시성 성능을 향상시킬 수 있습니다.

MySQL : 프로그래밍 언어는 아니지만 ...MySQL : 프로그래밍 언어는 아니지만 ...Apr 13, 2025 am 12:03 AM

MySQL은 프로그래밍 언어가 아니지만 쿼리 언어 SQL은 프로그래밍 언어의 특성을 가지고 있습니다. 1. SQL은 조건부 판단, 루프 및 가변 작업을 지원합니다. 2. 저장된 절차, 트리거 및 기능을 통해 사용자는 데이터베이스에서 복잡한 논리 작업을 수행 할 수 있습니다.

MySQL : 세계에서 가장 인기있는 데이터베이스 소개MySQL : 세계에서 가장 인기있는 데이터베이스 소개Apr 12, 2025 am 12:18 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

MySQL의 중요성 : 데이터 저장 및 관리MySQL의 중요성 : 데이터 저장 및 관리Apr 12, 2025 am 12:18 AM

MySQL은 데이터 저장, 관리, 쿼리 및 보안에 적합한 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1. 다양한 운영 체제를 지원하며 웹 응용 프로그램 및 기타 필드에서 널리 사용됩니다. 2. 클라이언트-서버 아키텍처 및 다양한 스토리지 엔진을 통해 MySQL은 데이터를 효율적으로 처리합니다. 3. 기본 사용에는 데이터베이스 및 테이블 작성, 데이터 삽입, 쿼리 및 업데이트가 포함됩니다. 4. 고급 사용에는 복잡한 쿼리 및 저장 프로 시저가 포함됩니다. 5. 설명 진술을 통해 일반적인 오류를 디버깅 할 수 있습니다. 6. 성능 최적화에는 인덱스의 합리적인 사용 및 최적화 된 쿼리 문이 포함됩니다.

MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점Apr 12, 2025 am 12:17 AM

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

InnoDB 잠금 장치 (공유 잠금, 독점 잠금, 의도 잠금, 레코드 잠금, 갭 잠금, 차세대 자물쇠)를 설명하십시오.InnoDB 잠금 장치 (공유 잠금, 독점 잠금, 의도 잠금, 레코드 잠금, 갭 잠금, 차세대 자물쇠)를 설명하십시오.Apr 12, 2025 am 12:16 AM

InnoDB의 잠금 장치에는 공유 잠금 장치, 독점 잠금, 의도 잠금 장치, 레코드 잠금, 갭 잠금 및 다음 키 잠금 장치가 포함됩니다. 1. 공유 잠금을 사용하면 다른 트랜잭션을 읽지 않고 트랜잭션이 데이터를 읽을 수 있습니다. 2. 독점 잠금은 다른 트랜잭션이 데이터를 읽고 수정하는 것을 방지합니다. 3. 의도 잠금은 잠금 효율을 최적화합니다. 4. 레코드 잠금 잠금 인덱스 레코드. 5. 갭 잠금 잠금 장치 색인 기록 간격. 6. 다음 키 잠금은 데이터 일관성을 보장하기 위해 레코드 잠금과 갭 잠금의 조합입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

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

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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