Издательский дом ООО "Гейм Лэнд"СПЕЦВЫПУСК ЖУРНАЛА ХАКЕР #52, МАРТ 2005 г.

Своя структура

Лавров Владислав (l-vv@r66.ru)

Спецвыпуск: Хакер, номер #052, стр. 052-024-3


Основным достоинством иерархической модели данных является простота ее восприятия и использования, а также быстрота доступа к данным. Но без недостатков тут не обошлось. Во-первых, не все связи между объектами в реальном мире подчиняются строгой иерархии, скорее наоборот… Во-вторых, из-за строгой иерархической упорядоченности объектов значительно усложняются операции включения и удаления (удаление исходных объектов приводит к удалению порожденных). Плюс сложность манипулирования данными в такой базе, поскольку требуется производить в явном виде навигационные операции, которые связаны с перемещением указателя, определяющего текущий экземпляр конкретного элемента данных.

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

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

При этом обе дореляционные (читай "дореволюционные") модели – иерархическая и сетевая – страдают одним большим недостатком: они слишком привязаны к конкретным данным. Эта зависимость послужила главным препятствием на пути к развитию реальных программных систем, основанных на базах данных: слишком много изменений приходилось вносить в код прикладной программы при каждой корректировке структуры базы (логическая зависимость), а также при изменении физического носителя данных (физическая зависимость).

Наконец, доктор наук математик Э.Ф. Кодд (США) придумал реляционную модель, гениальную по своей простоте. Единственной структурой данных, которую видит пользователь, является двухмерная таблица. Название "реляционная" происходит от слова relation (англ. "отношение"). Кодд придумал также основные операции, которые легко могут обработать данные в таблицах и получить результат в виде новой таблицы. Причем уникальность таких манипуляций данными в том, что за одну операцию можно обработать одновременно все данные таблицы и даже нескольких таблиц. И тебе не придется писать никаких циклических процедур, обрабатывая каждую запись отдельно!

Простота использования реляционной модели обеспечила ее безусловный успех, который длится вот уже более 30-ти лет. Одно из достоинств этой модели – возможность преобразовать любую структуру данных в простую двумерную таблицу.

Назад на стр. 052-024-2  Содержание  Вперед на стр. 052-024-4