Рассмотрим процесс построения логической модели на примере БД студентов системы «Служба занятости в рамках вуза». Первым этапом является определение сущностей и атрибутов. В БД будут храниться записи о студентах, следовательно, сущностью будет студент.
Таблица 1.Атрибуты сущности «Студент»
Атрибут | Описание |
Номер | Уникальный номер для идентификации пользователя |
Ф.И.О. | Фамилия, имя и отчество пользователя |
Пароль | Пароль для доступа в систему |
Возраст | Возраст студента |
Пол | Пол студента |
Характеристика | Memo-поле с общей характеристикой пользователя |
Адреса электронной почты | |
Телефон | Номера телефонов студента (домашний, рабочий) |
Опыт работы | Специальности и опыт работы студента по каждой из них |
Специальность | Специальность, получаемая студентом при окончании учебного заведения |
Специализация | Направление специальности, по которому обучается студент |
Иностранный язык | Список иностранных языков и уровень владения ими |
Тестирование | Список тестов и отметки о их прохождении |
Экспертная оценка | Список предметов с экспертными оценками по каждому из них |
Оценки по экзаменам | Список сданных предметов с оценками |
В полученном списке существуют атрибуты, которые нельзя определить в виде одного поля БД. Такие атрибуты требуют дополнительных определений и должны рассматриваться как сущности, состоящие, в свою очередь, из атрибутов. К таковым относятся: опыт работы, иностранный язык, тестирование, экспертная оценка, оценки по экзаменам. Определим их атрибуты.
|
|
Таблица 2. Атрибуты сущности «Опыт работы»
Атрибут | Описание |
Специальность | Название специальности, по которой у студента есть опыт работы |
Опыт | Опыт работы по данной специальности в годах |
Место работы | Наименование предприятия, где приобретался опыт |
Таблица 3. Атрибуты сущности «Иностранный язык»
Атрибут | Описание |
Язык | Название иностранного языка, которым владеет студент |
Уровень владения | Численная оценка уровня владения иностранным языком |
Таблица 4. Атрибуты сущности «Тестирование»
Атрибут | Описание |
Название | Название теста, который прошел студент |
Описание | Содержит краткое описание теста |
Оценка | Оценка, которую получил студент в результате прохождения теста |
Таблица 5. Атрибуты сущности «Экспертная оценка»
Атрибут | Описание |
Дисциплина | Наименование дисциплины, по которой оценивался студент |
Ф.И.О. преподавателя | Ф.И.О. преподавателя, который оценивал студента |
Оценка | Экспертная оценку преподавателя |
Таблица 6. Атрибуты сущности «Оценки по экзаменам»
|
|
Атрибут | Описание |
Предмет | Название предмета, по которому сдавался экзамен |
Оценка | Полученная оценка |
Составим ERD-диаграмму, определяя типы атрибутов и проставляя связи между сущностями (рис. 8). Все сущности будут зависимыми от сущности «Студент». Связи будут типа «один-ко-многим».
Рисунок 8
На полученной диаграмме рядом со связью отражается ее имя, показывающее соотношение между сущностями. При проведении связи между сущностями первичный ключ мигрирует в дочернюю сущность.
Следующим этапом при построении логической модели является определение ключевых атрибутов и типов атрибутов.
Таблица 7. Типы атрибутов
Атрибут | Тип | |
Номер | Number | |
Ф.И.О. | String | |
Пароль | String | |
Возраст | Number | |
Пол | String | |
Характеристика | String | |
String | ||
Специальность | String | |
Специализация | String | |
Опыт | Number | |
Место работы | String | |
Язык | String | |
Уровень владения | Number | |
Название | String | |
Описание | String | |
Оценка | Number | |
Дисциплина | String | |
Ф.И.О. преподавателя | String | |
Предмет | String |
Выберем для каждой сущности ключевые атрибуты, однозначно определяющие сущность. Для сущности «Студент» это будет уникальный номер, для сущности «Опыт работы» все поля являются ключевыми, так как по разным специальностям студент может иметь разный опыт работы в разных фирмах. Сущность «Тест» определяется названием, так как студент по одному тесту может иметь только одну оценку. Оценка по экзамену определяется только названием предмета, экспертная оценка зависит от преподавателя, который ее составил, поэтому в качестве ключевых атрибутов выберем «Дисциплину» и «Ф.И.О. преподавателя». У сущности «Иностранный язык» уровень владения зависит только от наименования языка, следовательно, это и будет являться ключевым атрибутом.