5.04
методическая разработка

для студентов 

Скачать:

ВложениеРазмер
Файл 5.04_bazy_dannyh.docx74.67 КБ

Предварительный просмотр:

5.04 Основы проектирования баз данных

Задание на выполнение

Задание 1

Выполнить проектирование базы данных  по образцу  в соответствии с номером варианта  (см. Приложение 1):

ФИО

Вариант

Беженарь Владислав

8

Беженарь Никита

2

Горев Тимофей

4

Кузнецов Александр

5

Кунин Александр

6

Лагутин Дмитрий

7

Лебедев Павел

3

Лебедев Максим

10

Ныкышев Тимур

24

Орлов Александр

11

Романов Константин

12

Русмиленко Анатолий

13

Русмиленко Александр

14

Сэротэтто Ольга

26

Ткачев Матвей

20

Турсунова Камила

29

Уткин Степан

16

Шакула Савелий

30

Яндо Всеволод

1

Варианты заданий и методические указания по выполнению индивидуального домашнего задания (ИДЗ) по теме «Базы данных»

Цели выполнения ИДЗ

  1. Научиться проектировать простейшие базы данных.
  2. Закрепить практические навыки работы с базами данных, полученные на практических занятиях.

Пример выполнения задания 1

Описание предметной области

Фирма выполняет ремонт компьютеров. Требуется разработать базу данных для хранения информации о выполнении ремонтных работ сотрудниками фирмы. При оформлении заказа фиксируется дата выполнения заказа, вид выполненной работы, исполнитель работы. Каждый исполнитель получает фиксированный процент вознаграждения от стоимости выполнения работы. Этот процент устанавливается персонально каждому исполнителю при заключении трудового договора между фирмой и работником. Исполнитель получает вознаграждение, которое вычисляется как Стоимость выполнения заказа * Фиксированный процент вознаграждения

Анализ описания предметной области позволяет выделить набор данных, которые должны храниться в проектируемой базе данных:

  1. Фамилия исполнителя работы;

  2. Имя исполнителя работы;
  3. Отчество исполнителя работы;

  4. Процент вознаграждения (может различаться для разных исполнителей);
  5. Наименование работы;

  6. Стоимость работы (фиксированная для каждого наименования работы);
  7. Дата исполнения работы.

Исходя из набора данных, которые должны храниться в БД, можно выделить два информационных объекта: Исполнитель (Фамилия, Имя, Отчество, Процент вознаграждения) и Работа (Наименование, Стоимость работы). Определим соответствующие таблицы ИСПОЛНИТЕЛИ и РАБОТЫ (рис. 1). Ни одно из первоначально заданных полей таблицы ИСПОЛНИТЕЛИ не определяет однозначно каждую запись таблицы, поэтому в таблицу введено поле Код исполнителя, значения в котором будут уникальными для каждого исполнителя. Это поле является первичным ключом таблицы ИСПОЛНИТЕЛИ и будет определено в Microsoft Access как ключевое поле. С этой же целью в таблицу РАБОТЫ введен первичный ключ Код работы.

Рис. 1. Таблицы ИСПОЛНИТЕЛИ и РАБОТЫ проектируемой базы данных

В таблице ИСПОЛНИТЕЛИ будут храниться записи вида:

1

Иванов

Андрей

Петрович

20

2

Алексеев

Игорь

Андреевич

25

В таблице РАБОТЫ будут храниться записи вида:

1

Установка микропроцессора

100.00 р.

2

Замена вентилятора

50.00 р.

Один исполнитель может выполнять различные работы. Одна и та же работа может быть выполнена разными исполнителями. Между таблицами ИСПОЛНИТЕЛИ и РАБОТЫ должна быть установлена связь типа «многие-ко- многим». Для организации такой связи потребуется новая таблица, в которую ключевые поля связываемых таблиц войдут как внешние ключи. Такой таблицей в нашем случае может быть таблица ЗАКАЗЫ. Данные в эту таблицу будут

заноситься при оформлении заказа на выполнение конкретной работы конкретным исполнителем. Из первоначального перечня атрибутов в эту таблицу войдет атрибут Дата исполнения работы. В таблице ЗАКАЗЫ также определим ключевое поле Код заказа.

Установим связи между таблицами посредством совпадающих полей в связываемых таблицах (рис. 2). Тип связи между таблицами ИСПОЛНИТЕЛИ и ЗАКАЗЫ – «один-ко-многим». Здесь таблица ИСПОЛНИТЕЛИ находится на стороне отношения «один», она является главной таблицей. Таблица ЗАКАЗЫ находится на стороне отношения «многие» и является подчиненной таблицей. Таблица РАБОТЫ является главной для связи между таблицами РАБОТЫ и ЗАКАЗЫ (связь «один-ко-многим»). А связь между таблицами ИСПОЛНИТЕЛИ и РАБОТЫ относится к типу «многие-ко-многим».

Рис. 2. Связи между таблицами проектируемой базы данных

Определим свойства полей в каждой из таблиц (см. табл. 1, 2, 3). При выборе имен полей рекомендуется выбирать короткие имена. Типы и размеры полей выбираются исходя из характера информации, которую предполагается хранить в поле.

Таблица 1. Свойства полей таблицы ИСПОЛНИТЕЛИ проектируемой БД

Имя поля в схеме

данных

Имя поля в

компьютерной БД

Тип поля

Размер поля

Код исполнителя

Код_исполнителя

счетчик

устанавливается

автоматически

Фамилия

Фамилия

текстовый

30 байт

Имя

Имя

текстовый

20 байт

Отчество

Отчество

текстовый

30 байт

Процент

вознаграждения

Процент

числовой

длинное целое

Таблица 2. Свойства полей таблицы РАБОТЫ проектируемой БД

Имя поля в схеме

данных

Имя поля в

компьютерной БД

Тип поля

Размер поля

Код работы

Код_работы

счетчик

устанавливается

автоматически

Стоимость работы

Стоимость

денежный

устанавливается

автоматически

Таблица 3. Свойства полей таблицы ЗАКАЗЫ проектируемой БД

Имя поля в схеме

данных

Имя поля в

компьютерной БД

Тип поля

Размер поля

Код заказа

Код заказа

счетчик

устанавливается

автоматически

Код работы

Код_работы

числовой

длинное целое

Код исполнителя

Код_исполнителя

числовой

длинное целое

Дата исполнения

Дата_исполнения

дата/время

-

Теперь наша база данных подготовлена к компьютерной реализации.

Приложение 1

Формулировка задания для выполнения ИДЗ (Задание 1) по теме «Базы данных»

Варианты 1, 11, 21. База данных «Платный прием в поликлинике»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

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

Пациент оплачивает за прием некоторую сумму, которая устанавливается персонально для

каждого врача. За каждый прием врачу отчисляется фиксированный процент от стоимости приема. Процент отчисления от стоимости приема на зарплату врача также устанавливается персонально для каждого врача.

Размер начисляемой врачу заработной платы за каждый прием вычисляется по формуле: Зарплата = Стоимость приема · Процент отчисления на зарплату. Из этой суммы вычитается подоходный налог, составляющий 13% от начисленной зарплаты.

  1. ФИО врача
  2. Специальность врача
  3. Стоимость приема
  4. Процент отчисления на зарплату
  5. Фамилия пациента
  6. Имя пациента
  7. Отчество пациента
  8. Дата рождения пациента
  9. Адрес пациента
  10. Дата приема
  1. ВРАЧИ
  2. ПАЦИЕНТЫ
  3. ПРИЕМ ПАЦИЕНТОВ

Варианты 2, 12, 22. База данных «Прокат автомобилей»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

Фирма выдает напрокат автомобили. При этом фиксируются данные о клиенте, данные об автомобиле, дата начала проката и количество дней проката, стоимость одного дня проката. Стоимость одного дня проката может отличаться для разных автомобилей.

Для каждого автомобиля определяется страховая стоимость. Стоимость проката автомобиля определяется как Стоимость одного дня проката · Количество дней проката. Фирма

ежегодно страхует автомобили,

  1. ФИО клиента
  2. Серия, номер паспорта клиента
  3. Модель автомобиля
  4. Цвет автомобиля
  5. Год выпуска автомобиля
  6. Госномер автомобиля
  7. Страховая стоимость автомобиля
  8. Стоимость одного дня
  1. КЛИЕНТЫ
  2. АВТОМОБИЛИ
  3. ПРОКАТ

выдаваемые клиентам. Страховой взнос, выплачиваемый фирмой, равен 10 процентам от страховой стоимости автомобиля.

проката

  1. Дата начала проката
  2. Количество дней проката

Варианты 3, 13, 23. База данных «Учет оптовых продаж магазина»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

Оптовый магазин закупает товар по цене закупки и продает товар по цене продажи. Разница между ценой продажи и ценой закупки составляет доход магазина от реализации каждой единицы товара.

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

Размер комиссионного вознаграждения за проданный товар определяется по

формуле: Комиссионное вознаграждение = Цена продажи единицы товара · Кол-во проданных единиц товара · Процент комиссионных.

Прибыль от продажи нескольких

единиц товара вычисляется как (Цена продажи - Цена закупки) · Количество проданных единиц товара.

  1. Наименование товара
  2. Единица измерения товара
  3. Цена закупки
  4. Цена продажи
  5. Дата продажи
  6. Количество проданных единиц товара
  7. ФИО продавца
  8. Процент комиссионных
  1. ТОВАРЫ
  2. ПРОДАВЦЫ
  3. ПРОДАЖИ

Варианты 4, 14, 24. База данных «Учет нарушений правил дорожного движения»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

При нарушении правил дорожного движения (ПДД) фиксируется

информация об автомобиле, водителе, его праве на управление автомобилем, о виде нарушения, размере штрафа.

Размер штрафа является

фиксированным и определяется видом нарушения.

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

  1. Модель автомобиля
  2. Год выпуска
  3. Госномер
  4. Страховая стоимость
  5. ФИО владельца
  6. Данные        паспорта владельца
  7. Вид нарушения ПДД
  8. Размер штрафа
  9. Дата нарушения ПДД
  10. ФИО водителя
  1. АВТОМОБИЛИ
  2. ВИДЫ

НАРУШЕНИЙ

  1. ФАКТЫ НАРУШЕНИЙ

страховании, равны 10 процентам от страховой стоимости автомобиля.

11. Право управления (владелец или по доверенности)

Варианты 5, 15, 25. База данных «Туристическое агентство»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

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

Стоимость поездки может быть вычислена как Стоимость 1 дня пребывания · Количество дней + Стоимость транспортных услуг + Стоимость оформления визы. Кроме того, клиент платит налог на

добавленную стоимость (НДС) в размере 18% от стоимости поездки.

  1. ФИО клиента
  2. Данные паспорта
  3. Страна назначения
  4. Цель поездки
  5. Стоимость 1 дня пребывания
  6. Стоимость транспортных услуг
  7. Стоимость оформления визы (определяется выбором маршрута)
  8. Дата начала поездки
  9. Количество дней
  1. КЛИЕНТЫ
  2. МАРШРУТЫ
  3. ПОЕЗДКИ

Варианты 6, 16, 26. База данных «Учет подписки на периодические печатные издания»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

Требуется создать базу данных для хранения информации о подписке на периодические печатные издания. При оформлении подписки на то или иное печатное издание следует указать

данные о подписчике, данные об издании, дату начала подписки и количество месяцев, на которые оформляется подписка.

Стоимость подписки может быть вычислена как Цена 1 экземпляра · Срок подписки. Клиент платит почтовому отделению 1% от стоимости подписки за доставку.

В стоимость подписки включается налог на добавленную стоимость (НДС), вычисляемый как Стоимость подписки·18%

  1. ФИО подписчика
  2. Улица
  3. Номер дома
  4. Номер квартиры
  5. Индекс издания по каталогу
  6. Вид издания (газета или журнал)
  7. Название издания
  8. Цена 1 экземпляра
  9. Дата начала подписки
  10. Срок подписки (количество месяцев)
  1. ИЗДАНИЯ
  2. ПОЛУЧАТЕЛИ
  3. ДОСТАВКА

Варианты 7, 17, 27. База данных «Учет сделок с недвижимостью»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

Фирма занимается оформлением сделок с объектами жилой

недвижимости. При оформлении сделки фиксируется информация о продаваемой квартире, о риэлторе,

оформляющем сделку купли-продажи, о дате оформления сделки.

Риэлтор, оформивший сделку купли- продажи, получает комиссионное вознаграждение, которое вычисляется как Цена квартиры · Процент вознаграждения. Процент

вознаграждения является индивидуальным и фиксированным для каждого конкретного риэлтора.

  1. Название улицы
  2. Номер дома
  3. Номер квартиры
  4. Площадь квартиры
  5. Количество комнат
  6. Дата сделки
  7. Цена квартиры
  8. ФИО риэлтора
  9. Процент вознаграждения
  1. КВАРТИРЫ
  2. РИЭЛТОРЫ
  3. СДЕЛКИ

Варианты 8, 18, 28. База данных «Учет договоров страхования»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

Договор страхования заключается между страховой компанией и клиентом на 1 год. При заключении

договора указывается вид страхования, страховая сумма, дата начала действия договора.

Каждый клиент выплачивает при заключении договора страховую премию. Размер страховой премии зависит от суммы страхования, тарифа и индивидуальной скидки клиента: Страховая премия = Сумма страхования · (Тариф - Процент скидки).

Тариф принимает значения от 1 до 5 процентов, индивидуальная скидка – от

0.1 до 5 процентов.

Каждый страховой агент получает комиссионное вознаграждение за заключение страхового договора, которое вычисляется как Комиссионные = Сумма страхования

· (Тариф - Процент скидки) · Процент вознаграждения.

  1. ФИО клиента
  2. Процент скидки
  3. Вид страхования (страхование имущества, автомобиля, жизни и т.д.)
  4. Тариф (зависит от вида страхования)
  5. Сумма страхования
  6. Дата заключения договора
  7. Фамилия агента
  8. Имя агента
  9. Отчество агента
  10. Процент вознаграждения
  1. КЛИЕНТЫ
  2. СТРАХОВЫЕ АГЕНТЫ
  3. ДОГОВОРЫ

Варианты 9, 19, 29. База данных «Штатное расписание»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

При составлении штатного расписания имеющиеся в организации штатные

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

Каждое подразделение характеризуется наименованием, типом, процентом

надбавки за вредные условия труда.

Заработная плата для каждой штатной единицы вычисляется как Размер зарплаты = Оклад ·(1+ Процент надбавки за вредные условия труда + Процент надбавки за ненормированный рабочий день). С начисленной заработной платы вычитается подоходный налог, равный 13 процентам от размера зарплаты.

  1. Название подразделения
  2. Тип подразделения (цех, отдел, бригада и т.д.)
  3. Процент надбавки 1 (за вредные условия труда, зависит от

подразделения, принимает значения от 0 до 100%)

  1. Название должности
  2. Должностной оклад
  3. Процент надбавки 2 (за ненормированный

рабочий день, устанавливается для конкретной штатной единицы от 0 до 100%)

  1. Отпуск (количество дней отпуска в году, устанавливается для конкретной штатной

единицы)

  1. ПОДРАЗДЕЛЕНИЯ
  2. ШТАТНЫЕ ЕДИНИЦЫ
  3. РАСПРЕДЕЛЕНИЕ ШТАТНЫХ

ЕДИНИЦ

Варианты 10, 20, 30. База данных «Учет результатов сдачи вступительных экзаменов»

Описание предметной области

Минимальный набор полей базовых таблиц

Предлагаемый набор базовых таблиц

База данных должна содержать информацию об абитуриентах, экзаменаторах и результатах сдачи

вступительных экзаменов. О каждом факте сдачи экзамена указываются: дата сдачи экзамена, название экзамена, кто сдавал экзамен, кто принимал экзамен, каков результат сдачи экзамена,

Экзаменатор получает за прием экзамена установленную оплату, которая назначается индивидуально. С этой суммы удерживается подоходный налог в размере 13%. Учебное

заведение отчисляет в бюджет социальный налог в размере 20% от начисленной преподавателю оплаты за прием экзамена.

  1. ФИО абитуриента
  2. Адрес
  3. Год рождения абитуриента
  4. Серия-номер паспорта абитуриента
  5. ФИО экзаменатора
  6. Размер оплаты (за прием экзамена у одного

абитуриента, может различаться для разных преподавателей)

  1. Дата сдачи экзамена
  2. Название экзамена (история, математика и т.д.)
  3. Оценка
  1. АБИТУРИЕНТЫ
  2. ЭКЗАМЕНАТОРЫ
  3. ЭКЗАМЕНЫ