ОСНОВЫ ПРОЕКТИРОВАНИЯ РЕЛЯЦИОННЫХ БАЗ ДАННЫХ (РБД)
Основные понятия РБД
В каждой таблице БД должно существовать поле или набор полей, которые однозначно идентифицируют каждую запись, хранящуюся в таблице (что и обеспечивает отсутствие одинаковых строк в таблице). Такие поля называют первичными (уникальными) ключамиили главными ключамиили ключевыми полями (ключ). Первичный ключ называется простым,когда он состоит из одного поля, или составным, когда он состоит из нескольких полей.
Чтобы правильно выбрать первичный ключ, следует учитывать его основные характеристики:
1) он однозначно определяет каждую строку;
2) в нем нет пустых или отсутствующих значений – он всегда содержит значение; первичный ключ не может принимать нулевое значение;
3) если он и меняется, то крайне редко.
В БД слово «ключ» имеет несколько употреблений:
ключ поиска – поле, по значению которого ищется запись в БД,
ключ сортировки – поле, по значению которого происходит упорядочение записей.
Связи между таблицами устанавливают с помощью ключевых полей. При этом таблицу, в которой задан первичный ключ, называют главной, а связанную с ней таблицу – подчиненной. Чтобы связать две реляционные таблицы, необходимо ключ главной таблицы ввести в состав подчиненной таблицы; в противном случае нужно ввести в структуру первой таблицы внешний ключ– ключ второй таблицы.
Ключ к записям в БД может быть простым, составным, первичным и внешним.
[слайд 24]
РБД имеет табличную форму организациии представляет собой совокупность логически взаимосвязанных двумерных таблиц.
[слайд 25]
А – главная таблица
Б – подчиненная таблица
1) 1:1 «один к одному» – одна запись таблицы А связана только с одной записью таблицы Б.
2) 1:М «один ко многим» – одна запись таблицы А связана более чем с одной записью таблицы Б.
3) М:1 «многие к одному» – несколько записей таблицы А связаны только с одной записью таблицы Б.
4) М:М «много ко многим» – несколько записей таблицы А связаны более чем с одной записью таблицы Б.
Наличие межтабличных связей позволяет одновременно отображать родственные сведения из нескольких таблиц.