반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- Python
- SRE
- Pro-Con
- 제노블레이드 2
- 코딩테스트
- programmers
- GitHub Desktop
- 자소서
- git
- algorithm
- LeetCode
- baekjoon
- python3
- 프로그래머스
- 프로콘 갈림현상
- Ultimate Search
- C++
- 리트코드
- 백트래킹
- Github
- 알고리즘
- 네이버 검색 시스템
- 알고리즘 종류 정리
- 프로콘
- 백준
- DP
- Algorithmus
- ASF-110
- 격리수준
- 취준
Archives
- Today
- Total
산타는 없다
MySql의 인덱스 자료구조 본문
반응형
일반적으로 데이터베이스의 인덱스 자료구조는 B / B+ tree 또는 Hash입니다.
Hash 자료구조 인덱스는 equal 검색을 빠르게 수행할 수 있지만, 대소 비교 및 정렬에서는 사용할 수 없는 단점이 있습니다. 반면에 B / B+ tree는 equal연산이 Hash보다 약간 느리지만 대소 비교 및 정렬에서도 사용할 수 있습니다.
그 중 MySql의 인덱스 자료구조가 어떤 자료구조로 이루어져 있는지 찾아보았습니다.
결과를 말씀드리자면 MySql은 MyISAM, InnoDB, Archive 등과 같은 엔진을 사용하는데
엔진마다 사용하는 자료구조가 다릅니다.
엔진 | 인덱스 자료구조 | 엔진 특징 |
MyISAM | B tree | 트랜잭션을 지원하지 않고, Table 단위의 Locking입니다. 따라서, 다수개의 세션이 동시에 작업하는 경우 성능이 저하될 수 있습니다. |
InnoDB | B+ tree | MySQL에서 기본으로 설정되는 엔진이며 일반적인 DBMS 기능을 지원합니다. |
Archive | X | Archive는 로그 수집에 적합한 엔진으로 데이터가 메모리상에서 압축된 후, 압축된 상태로 디스크에 저장됩니다. 한번 Insert 된 데이터는 Update나 Delete를 할 수 없으며, 인덱스를 지원하지 않기 때문에 인덱스 자료구조가 없습니다. |
반응형
'Computer Science > 데이터베이스' 카테고리의 다른 글
[MySql] SQL select Query 실행 순서 (0) | 2021.07.14 |
---|---|
데이터베이스 B/B+ tree 인덱스 구조 (0) | 2021.05.17 |
데이터베이스의 인덱스 알고리즘 (0) | 2021.05.14 |
MySql의 스토리지 엔진 비교 (0) | 2021.05.13 |
트랜잭션(Transaction) 격리 수준(Isolation Level) (0) | 2021.04.27 |
Comments