Калькированный
термин «В-дерево», в котором смешивается английский символ «В»
и добавочное слово на русском языке, настолько устоялся в литературе, посвященной
организации физического хранения данных, что я не решусь его корректировать.
Встретив
как-то термин «B-дерево», я долго его трактовала, потому что привыкла
уже к устоявшемуся обозначению. Поэтому будем работать с этим термином.
Построение
В-деревьев связано с простой идеей построения индекса над уже построенным индексом.
Действительно, если мы построим неплотный индекс, то сама индексная область
может быть рассмотрена нами как основной файл, над которым надо снова построить
неплотный индекс, а потом снова над новым индексом строим следующий и так до
того момента, пока не останется всего один индексный блок.
Мы в общем
случае получим некоторое дерево, каждый родительский блок которого связан с
одинаковым количеством подчиненных блоков, число которых равно числу индексных
записей, размещаемых в одном блоке. Количество обращений к диску при этом для
поиска любой записи одинаково и равно количеству уровней в построенном дереве.
Такие деревья называются сбалансированными (balanced) именно потому, что путь
от корня до любого листа в этом древе одинаков. Именно термин «сбалансированное»
от английского «balanced» — «сбалансированный, взвешенный»
и дал название данному методу организации индекса.
Построим
подобное дерево для нашего примера и рассчитаем для него количество уровней
и, соответственно, количество обращений к диску.
На первом
уровне число блоков равно числу блоков основной области, это нам известно, —
оно равно 12 500 блоков. Второй уровень образуется из неплотного индекса, мы
его тоже уже строили и вычислили, что количество блоков индексной
области в этом случае равно 172 блокам. А теперь над этим вторым уровнем снова
построим неплотный индекс.
Мы не будем
менять длину индексной записи, а будем считать ее прежней, равной 14 байтам.
Количество индексных записей в одном блоке нам тоже известно, и оно равно 73.
Поэтому сразу определим, сколько блоков нам необходимо для хранения ссылок на
172 блока.
КIВ3
= KIB2/KZIB = 172/73 = 3 блока
Мы снова
округляем в большую сторону, потому что последний, третий, блок будет заполнен
не полностью.
И над третьим
уровнем строим новый, и на нем будет всего один блок, в котором будет всего
три записи. Поэтому число уровней в построенном дереве равно четырем, и соответственно
количество обращений к диску для доступа к произвольной записи равно четырем
(рис. 9.9). Это не максимально возможное число обращений, а всегда одно и то
же, одинаковое для доступа к любой записи.
Тд=
Rуравн. =4
1 уровень 12500
блоков
2 уровень 172
блоков
3 уровень 3
блоков
4 уровень 1
блоков
Рис.
9.9. Построенное В-дерево
Механизм
добавления и удаления записи при организации индекса в виде В-дерева аналогичен
механизму, применяемому в случае с неплотным индексом.
И наконец,
последнее, что хотелось бы прояснить, — это наличие вторых названий для плотного
и неплотного индексов.
В случае
плотного индекса после определения местонахождения искомой записи доступ к ней
осуществляется прямым способом по номеру записи, поэтому этот способ организации
индекса и называется индексно-прямым.
В случае неплотного индекса после нахождения блока, в котором расположена искомая запись, поиск внутри блока требуемой записи происходит последовательным просмотром и сравнением всех записей блока. Поэтому способ индексации с неплотным индексом называется еще и индексно-последовательным.