B-Tree is a specialized m-way tree that can be widely used for disk access. A B-Tree of order m can have at most m-1 keys and m children. One of the main reason of using B-Tree is its capability to store large number of keys in a single node and large key values by keeping the height of the tree relatively small.
Properties of B-Tree –
- A B-Tree is defined by the term minimum degree ‘t’
- Every node except root must contain at least (t – 1) keys. Root may contain minimum 1 key.
- All nodes (including root) may contain at most (2t – 1) keys.
- Number of children of a node is equal to the number of keys in it plus 1.
- All keys of a node are sorted in increasing order. The child between two keys k1 and k2 contains all keys in the range from k1 and k2.
B-Tree Insertion
Let us understand the algorithm with an example tree of minimum degree ‘t’ as 3 and a sequence of integers 10, 20, 30, 40, 50, 60, 70, 80 and 90 in an initially empty B-Tree.
Initially root is NULL. Let us first insert 10.
data:image/s3,"s3://crabby-images/55e3a/55e3a99eca837d774252afcc61e78039602deba9" alt=""
Let us now insert 20, 30, 40 and 50. They all will be inserted in root because maximum number of keys a node can accommodate is 2*t – 1 which is 5.
data:image/s3,"s3://crabby-images/1837a/1837a1fac7189f9e6874804926e4dd16aaaf1925" alt=""
Let us now insert 60. Since root node is full, it will first split into two, then 60 will be inserted into the appropriate child.
data:image/s3,"s3://crabby-images/6dd77/6dd773f0e9a9999a247232dff7e2ebde5e76e275" alt=""
Let us now insert 70 and 80. These new keys will be inserted into the appropriate leaf without any split.
data:image/s3,"s3://crabby-images/5a5dc/5a5dc658eab22d5b4b4e15317dc4ce1fb6e6f330" alt=""
Let us now insert 90. This insertion will cause a split. The middle key will go up to the parent.
data:image/s3,"s3://crabby-images/44b0f/44b0fc068433999f44fa3eb2c0eaa7f28f1b04d9" alt=""
Initial Tree
data:image/s3,"s3://crabby-images/1ff61/1ff61af2d7ef3131a5ec06e3ba2dcda11ff0af26" alt=""
After delete 60 the Tree will be
data:image/s3,"s3://crabby-images/37f06/37f068585fb0bfa0e3688a1fa28675b92f089822" alt=""
After delete 20 the Tree will be
data:image/s3,"s3://crabby-images/b6158/b6158d42a011c9078e2c30eb9d6312c5e309c160" alt=""
After delete 30 the Tree will be
data:image/s3,"s3://crabby-images/e2be2/e2be2c3aed4ed81dfdf2942564e51a2782f83352" alt=""