Хомоненко А.Д., Цыганков В.М., Мальцев М.Г. - Базы данных. Учебник для высших учебных заведений (6-е изд.) - 2009 (960530), страница 85
Текст из файла (страница 85)
Д л я таблиц Paradox таким является поле402Часть 3. Современные СУБД и их применениеавтоинкрементного типа, еще одним достоинством которого является небольшой размер (4 байта). В то же время в таблицах dBase и InterBase поле подобного типа отсутствует, и программист должен обеспечивать уникальностьзначений ключа самостоятельно, например, используя специальные генераторы.Отметим, что при создании и ведении БД правильным подходом считается задание в каждой таблице ключа даже в случае, если на первый взгляд онне нужен.Индекс, как и ключ, строится по полям таблицы, однако он может допускать повторение значений составляющих его полей — в этом и состоит егоосновное отличие от ключа.
Поля, по которым построен индекс, называютиндексными. Простой индекс состоит из одного поля, а составной (сложный) —из нескольких полей.Индексы при их создании именуются. Как и в случае с ключом, в зависимости от С У Б Д индексы могут храниться в отдельных файлах или совместнос данными. Создание индекса называют индексированием таблицы.Сортировка представляет собой упорядочивание записей по полю илигруппе полей в порядке возрастания или убывания их значений. Можно сказать, что индекс служит для сортировки таблиц по индексным полям.
В частности, в С++ Builder записи набора Table можно сортировать только поиндексным полям. Набор данных Query позволяет выполнить средствамиSQL сортировку по любым полям, однако и в этом случае для индексированных полей упорядочивание записей выполняется быстрее.Для одной таблицы можно создать несколько индексов.
В каждый моментвремени один из них можно сделать текущим, т. е. активным. Даже при существовании нескольких индексов таблица может не иметь текущего индекса(текущий индекс важен, например, при выполнении поиска и сортировки записей набора данных Table).Ключевые поля обычно автоматически индексируются. В таблицахParadox ключ также является главным (первичным) индексом, которыйне именуется. Д л я таблиц dBase ключ не создается, и его роль выполняетодин из индексов.
Создание ключа может привести к побочным эффектам. Так, если в таблице Paradox определить ключ, то записи автоматически упорядочиваются по его значениям, что в ряде случаев является нежелательным.Одной из основных задач БД является обеспечение быстрого доступак данным (поиска данных). Время доступа к данным в значительной степенизависит от используемых для поиска данных методов и способов./ I. Borland С++ Builder403СпособыдоступакданнымПри выполнении операций с таблицами в С + + Builder используется одиниз следующих способов доступа к данным:• навигационный;• реляционный.Навигационный способ доступа заключается в обработке каждой отдельной записи таблицы.
Этот способ обычно используется в локальных Б Д илив удаленных Б Д небольшого размера. Если необходимо обработать несколько записей, то все они обрабатываются поочередно.Реляционный способ доступа основан на обработке сразу группы записей,при этом если необходимо обработать одну запись, то обрабатывается группа, состоящая из одной записи. Так как реляционный способ доступа основывается на SQL-запросах, его также называют SQL-ориентированным.Этотспособ доступа ориентирован на выполнение операций с удаленными Б Д иявляется предпочтительным при работе с ними, хотя его можно использовать и для локальных БД.Способ доступа к данным выбирается программистом и зависит от средствдоступа к БД, используемых при разработке приложения.
Например, в приложениях, создаваемых в С + + Builder, реализацию навигационного способадоступа можно осуществить посредством компонентов Table или Query, а реляционного — с помощью компонента Query.Таким образом, методы доступа к данным определяются структурой БД, аспособы доступа — приложением.Связь междутаблицамиСвязи между таблицами можно устанавливать как при создании БД, так ипри выполнении приложения, используя средства, предоставляемые С У Б Д .Связывать можно две или несколько таблиц. В реляционной БД, помимо связанных таблиц, могут быть и отдельные таблицы, не соединенные ни с однойдругой таблицей.Д л я связывания таблиц используются поля связи. О н и обязательно должны быть индексированными.
В подчиненной таблице для связи с главной таблицей задается индекс, который также называется внешним ключом. Составполей этого индекса должен полностью или частично совпадать с составомполей индекса главной таблицы.Особенности использования индексов зависят от формата связываемыхтаблиц. Так, для таблиц dBase индексы строятся по одному полю и нет деления на ключ (главный или первичный индекс) и индексы.Д л я организации связи в главной и подчиненной таблицах выбираютсяиндексы, составленные по полям совпадающего типа, например, целочисленного.Часть 3. Современные СУБД и их применение404Для таблиц Paradox в качестве полей связи главной таблицы должны использоваться поля ключа, а для подчиненной таблицы — поля индекса. Кроме того, в подчиненной таблице обязательно должен быть определен ключ.На рис.
11.13 показана схема связи между таблицами БД Paradox.Главная таблицаПодчиненная таблицаКлючИндекс (внешний ключ)M_Code•• •Ключевоеполе•••D_NumD_Code•• •КлючевоеполеИндексноеполе•••Рис. 11.13. Схема связи между таблицами базы данных ParadoxВ главной таблице определен ключ, построенный по полю M _ C o d e автоинкрементного типа. В подчиненной таблице определен ключ по полюD Num также автоинкрементного типа и индекс, построенный по полюD _ C o d e целочисленного типа.
Связь между таблицами устанавливается пополям D _ C o d e и M _ C o d e . Индекс по полю D C o d e является внешним ключом. В названия полей включены префиксы, указывающие на принадлежность поля соответствующей таблице. Так, названия полей главной таблицы начинаются с буквы М (Master), а названия полей подчиненной таблицыначинаются с буквы D (Detail). Подобное именование полей облегчает ориентацию в их названиях, особенно при большом количестве таблиц.Как отмечалось, поля связи должны быть индексированными, хотя, строго говоря, это требование не всегда является обязательным.
При доступе кданным средствами языка SQL можно связать (соединить) между собой таблицы и по неиндексированным полям. Однако в этом случае скорость выполнения операций будет низкой.Связь между таблицами определяет отношение подчиненности, при котором одна таблица является главной (родительской, или мастером — Master),а вторая — подчиненной (дочерней, или детальной — Detail).
Саму связь (отношение) называют связь «главный-подчиненный», «родительский-дочерний» или «мастер-детальный».После установления связи между таблицами при перемещении на какуюлибо запись в главной таблице в подчиненной таблице автоматически становятся доступными записи, у которых значение поля связи равно значениюполя связи текущей записи главной таблицы. Такой отбор записей подчиненной таблицы является своего рода фильтрацией.Ограничения по установке, изменению полей связи и каскадному удалениюзаписей могут быть наложены на таблицы при их создании.
Эти ограничения,наряду с другими элементами, например описаниями полей и индексов, вхо-/ I. Borland С++ Builder405дят в структуру таблицы и действуют для всех приложений, которые выполняют операции с БД. Указанные ограничения можно задать при создании илиреструктуризации таблицы, например, в среде программы Database Desktop,которая позволяет устанавливать связи между таблицами при их создании.О г р а н и ч е н и я , с в я з а н н ы е с установкой, и з м е н е н и е м з н а ч е н и й полей с в я з и икаскадным удалением записей, могут и не входить в структуру таблицы (таблиц), а реализовываться программным способом. В этом случае программистдолжен обеспечить:• организацию связи между таблицами;• установку значения поля связи подчиненной таблицы (это может такжевыполняться автоматически);• контроль (запрет) редактирования полей связи;• организацию (запрет) каскадного удаления записей.Например, в случае удаления записи из главной таблицы программистдолжен проверить наличие соответствующих записей в подчиненной таблице.
Если такие записи есть, то необходимо удалить и их или, наоборот, запретить удаление записей из обеих таблиц. И в том, и в другом случае пользователю должно быть выдано предупреждение.ФорматытаблицС + + Builder не имеет своего формата таблиц, но поддерживает как собственные два типа локальных таблиц — dBase и Paradox.
Каждая из этих табл и ц имеет свои особенности.Таблицы dBase являются одним из первых появившихся форматов таблицдля персональных компьютеров и поддерживаются многими системами, которые связаны с разработкой и обслуживанием приложений, работающих сБД. Основные достоинства таблиц dBase: простота использования и совместимость с большим числом приложений.Таблицы dBase являются достаточно простыми и используют для своегохранения на дисках относительно мало физических файлов. По расширениюфайлов можно определить, какие данные они содержат.• dbf — таблица с данными.• d b t — данные больших двоичных объектов, или BLOB-данные (BinaryLarge OBject).
К ним относятся двоичные, Memo- и OLE-поля. Мешополе также называют полем комментариев.• mdx — поддерживаемые индексы.• ndx — индексы, непосредственно не поддерживаемые форматом dBase.При использовании таких индексов программист должен обрабатыватьих самостоятельно.И м я поля в таблице dBase должно состоять из букв и ц и ф р и начинаться сбуквы. Максимальная длина имени составляет 10 символов. В имена нельзявключать специальные символы и пробел.Часть 3. Современные СУБД и их применение406К недостаткам таблиц dBase относится то, что они не поддерживают автоматическое использование парольной защиты и контроль целостности связей, поэтому программист должен кодировать эти действия самостоятельно.Таблицы Paradox являются достаточно развитыми и удобными для созданияБД.