×
Traktatov.net » Мир InterBase. Архитектура, администрирование и разработка приложений баз данных в InterBase/FireBird/Yaffil » Читать онлайн
Страница 246 из 302 Настройки

Размер стр

аницы, байт





1024

2048

4096

8192

16384

InterBase 4 0

*

*

*

*


InterBase 5.x

*

*

*

4


InterBase 6 Ox

*

*

*

*


Firebird Ix/Yaffl 1.x /InterBase 6.5 и выше

*

*

*

*

*

Чтение и запись данных в базе данных осуществляется постранично, и многие важные характеристики базы данных и сервера, такие, например, как размер буфера базы данных (Database cache), зависят от размера страницы и исчисляются в "страницах".

Давайте откроем какую-нибудь базу данных InterBase с помощью IBSurgeon. Для этого достаточно дважды щелкнуть по файлу базы данных. На рисунке 4.2 изображен список страниц, который показывается после того, как IBSurgeon открыл базу данных.





Рис 4.2. Список страниц базы данных

Страницы бывают различных типов, каждый из которых служит определенной цели. Взаимозависимости различных типов страниц условно представлены на рис. 4.3. Он схематично изображает расположение страниц в файле базы данных - слева направо, сверху вниз, если считать от начала файла. Страницы одного типа не идут строго одна за другой - они могут быть перемешаны свободно, располагаясь в файле в том порядке, в котором они создавались сервером при расширении или создании базы данных.

Некоторые типы страниц выглядят "болтающимися без дела", т. е. не имеющими ссылок на другие типы страниц. Однако здесь нет никакого противоречия, просто эти типы страниц связаны и используются на другом структурном уровне, они могут связываться с помощью таблицы RDBSPAGES и других системных таблиц (эта таблица и другие системные объекты будут рассмотрены ниже, в разделе "Логическая структура базы данных"). На рис. 4.3 изображены только явные ссылки между страницами на физическом уровне.

Рассмотрим подробнее, какие бывают типы страниц в базе данных InterBase. В файле ods.h из набора исходных кодов InterBase находится информация обо всех возможных типах страниц. К этому файлу мы будем часто обращаться, чтобы из первоисточника получить данные не только об ODS, но и о многих других основополагающих вещах ядра InterBase.





Pис 4.3. Взаимозависимости ме/KCjv разимными типами страниц в базе данных InterBase

Всего задекларировано 11 типов страниц, однако достойны объяснения лишь 9 из них, что ясно видно из табл. 4.22. Типы страниц с идентификаторами 0 и 10 не определены или не используются

Табл 4.22. Типы страниц

Определение в ods.h

Идентификатор страницы

Английское название страницы

Русская интерпретации английского названия

pag_undefmed

0

Undefined - If a page has this page type it is probably free

Неопределенный тип страницы - возможно, страница свободна

pag_header

1

Database header page

Страница заголовка базы данных

P°g_pages

2

Page inventory page (or Space inventory

page - SIP)

Страница, хранящая информацию о распределении страниц

pag_transactions

3

Transaction inventory page (TIP)

Страница учета транзакций

pag_pomter

4

Pointer page

Страница указателей

pag_data

5

Data page

Страница данных

pag_root

6

Index root page

Страница вершины индекса

pagjndex

7

Index (B-tree) page

Страница индексов

pag_blob

8

Blob data page

Страница для хранения ВЮВ-данных

pagjds

9

Gen-ids