Skip to content

alexander-deb/car_services_db

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 

Repository files navigation

База данных для сети автосервисов

Цели: Получить необходимые практические навыки работы с БД, для их использования в сфере бизнеса. Придумать хорошую модель БД, которой смогут воспользоваться реальные компании. Научиться грамотно работать с SQL-запросами.

Мотивация: Сделать хорошо работающую модель данных для использования ее в бизнесе. Возможно сделать приложение для нашей базы, которое будет выполнять минимальные требования и с ним выйти на рынок.

Возможные проблемы: Это только базовый функционал. В таблицах нет многих атрибутов, которые могли бы быть. Так же в зависимости от возможностей сети автосервисов нужно будет добавлять новые сущности. Из-за того, что таблицы приведены к 2-НФ, появилось большое количество внешних ключей. Поэтому для написания запросов понадобится компетентный человек, хорошо разбирающийся в базах данных. Также я не эксперт в области автосервисов, а просто люблю наблюдать за их работой, то возможно в модели есть бесполезные сущности, которые мало используются на практике.

Концептуальная модель

image

Логическая модель

image

Примечание: Все таблицы находятся в 2-НФ

Физическая модель

CarService Автосервисы

Название Описание Тип данных Ограничение
sevice_ID ID автосервиса INT NOT NULL
address Адресс VATCHAR(100) NOT NULL
phone_number Телефон VARCHAR(12) NOT NULL
company_name Наименование компании VARCHAR(50) NOT NULL

Places Помещения

Название Описание Тип данных Ограничение
address Адресс VATCHAR(100) NOT NULL
sevice_ID ID автосервиса INT NOT NULL
square Площадь(м^2) INT NOT NULL
rent_price Цена аренды(руб/мес) INT NOT NULL

Employees Сотрудники

Название Описание Тип данных Ограничение
employee_ID ID сотрудника INT NOT NULL
full_name ФИО VARCHAR(50) NOT NULL
sevice_ID ID Автосервиса-работодателя INT NOT NULL
phone_number Контактный телефон сотрудника VARCHAR(12) NOT NULL
passport_number Паспортные данные VARCHAR(50) NOT NULL

Orders Заказы

Название Описание Тип данных Ограничение
order_ID ID заказа INT NOT NULL
employee_ID ID сотрудника, взявшего заказ INT NOT NULL
serial_number_of_details Серийный номер заказанной детали VARCHAR(50) NOT NULL
sevice_ID ID Автосервиса-выполняющего INT NOT NULL
price_of_job Цена работ(руб) INT NOT NULL

Clients Клиенты

Название Описание Тип данных Ограничение
client_ID ID клиента INT NOT NULL
order_ID ID заказа INT NOT NULL
full_name ФИО клиента VARCHAR(50) NOT NULL

Components Детали

Название Описание Тип данных Ограничение
serial_number Серийный номер детали VARCHAR(50) NOT NULL
order_ID ID заказа INT NOT NULL
price Цена детали INT NOT NULL
manufacturer Производитель VARCHAR(100) NOT NULL
provider_adress Адрес поставщика VARCHAR(100) NOT NULL

Providers Поставщики

Название Описание Тип данных Ограничение
address Серийный номер детали VARCHAR(50) NOT NULL
service_ID ID сервиса, с которым заключен контракт INT NOT NULL
company_name Название компании-поставщика VARCHAR(50) NOT NULL
city Город поставщика VARCHAR(50) NOT NULL

Equipment Оборудование

Название Описание Тип данных Ограничение
serial_number Серийный номер VARCHAR(100) NOT NULL
provider_address Адрес поставщика VARCHAR(100) NOT NULL
service_ID ID Автосервиса INT NOT NULL
country_of_manufacturer Страна производителя VARCHAR(50) NOT NULL
company_name Название компании-поставщика VARCHAR(50) NOT NULL
price Цена(руб) INT NOT NULL

Итоги

  • Использование 2-НФ упрощает работу с Базой данных во время проектирования. Но пока не понятно, насколько легко можно будет писать запросы в базу.
  • Спроектированная модель подходит для использования реальными автосервисами в их работе.
  • При реализации модели нужно полностью соответствовать тому, к чему мы пришли при создании физической модели. Иначе это может обернуться финансовыми потерями для компаний

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •