일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
- Symbol
- 포인터
- UNIX Internals
- 전처리기
- OS 커널
- DBMS 개발
- kernel
- Pointer
- 커널
- Preprocessor
- 포인터변수
- FreeBSD
- bash
- newSQL
- Windows via c/c++
- Golang
- 약어
- 구조와 원리
- DBMS
- Programming
- UNIX
- 한빛미디어
- TiDB
- 컴퓨터 강좌
- 긴옵션
- TiKV
- go
- 함수포인터
- SQLite
- getopts
- Today
- Total
sonumb
Bottom-up B+ Tree Construction Algorithm 본문
1. The records in the sorted input file are arranged into buckets (leaf nodes) which are 70% full.
2. Create the first node of the parent-of-leaf level in memory. Read in the first sorted leaf. Put the address of this leaf in the parent in memory.
3. Read in another sorted leaf. Put its lowest key value in the node at the lowest level which is not yet 70% full. If all nodes in the index are 70% full, create a new root. Put the key value from the current leaf node in the new root.
4. If the current index entry is above the parent-of-leaf level, create new nodes on all levels between the one where the entry is being placed and the leaf level. Put the address of each new node in the node above it. Put the address
of the leaf node in its parent. While creating the B+ tree, the memory may fill, but for the sake of this homework you can assume that all index nodes (except the leaves) fit in memory.
5. Repeat steps 3 and 4 until the sorted leaves are exhausted.
6. Clean up. At the end, there may be sparse nodes on the right-most position in any level. Adjust the tree structure. Flush all the nodes to the disk.