数据库logo

数据库设计

由Rikky提供

所有类别:

Основы баз данных (文章图片)

Основы баз данных

Проектирование БД простыми словами

Примеры баз данных (文章图片)

Примеры баз данных

Разбираем архитектуру БД на популярных примерах

Восстановление БД (文章图片)

Восстановление БД

Исправление частых ошибок без потери данных

Новости проекта (文章图片)

Новости проекта

Обновления, новые функции, и прочие события

Примеры SQL запросов (文章图片)

Примеры SQL запросов

Основы SQL простыми словами, операторы SQL

Основы проектирования БД: нормализация данных простыми словами, для чего нужны связи в реляционной БД, связь «один ко многим»

Нормализация данных простыми словами

Структуру базы данных необходимо проектировать таким образом, чтобы данные в ней не дублировались. Удобнее всего это делать не в СУБД, а в визуальном конструкторе схем баз данных, таком как например Database Design, чтобы вся схема бд была как на ладони.

Допустим мы проектируем структуру бд интернет-магазина. Нам нужно хранить данные о товарах, которые в нём будут продаваться. Также каждый товар принадлежит к одной из категорий товаров. Как нам хранить эти данные?

Первое что может прийти в голову - создать таблицу для товаров, хранить в каждой записи товара его название, описание, цену, и название категории: 2023-11-21_17-59-54.png Почему так лучше не делать? Представьте ситуацию, что интернет-магазин уже действует, у него много категорий и много товаров. Потребовалось изменить название одной из категорий. При такой реализации для этого придётся вносить изменения в каждую из записей в таблице товаров, заменяя название категории на новое.

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

Как же следует поступить? Обратимся к главному преимуществу реляционных баз данных: возможности создавать связи между таблицами. Нам просто нужно создать для хранения данных о категориях товаров другую таблицу. Таким образом, когда нам нужно изменить название категории, изменение будет затрагивать только одну запись: 2023-11-21_18-14-49.png

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

Как же теперь нам понять, к какой категории принадлежит товар? Нужно создать связь между товарами и категориями. Чтобы это сделать, мы добавляем в таблицу товаров поле category_id, и в каждой записи товара будем хранить там id записи категории.

id - уникальный (не повторяющийся) номер, который есть у каждой записи в любой таблице (исключение - таблицы связи многие ко многим, но об этом позже). Внутри одной таблицы не может быть два одинаковых id, что позволяет нам с 100% точностью получить нужную запись по её уникальному номеру

Смотрите, как это выглядит: 2023-11-21_18-37-28.png Храня в записях товаров уникальный номер категории к которым они принадлежат, мы можем получая каждый товар, получать вместе с ними все данные о категории:

SELECT
       p.id, p.name, p.description, p.price, 
       c.id as 'category_id', c.name as 'category_name', c.image as 'category_image'
 FROM
       product p, category c
 WHERE
       p.category_id = c.id;

Связь один ко многим

На скриншоте выше, мы создали связь "один ко многим", также обозначается как one-to-many или 1:М. Опять же проще объяснить на примере: в нашей связи "один" это категория, а "многие" - товары.

Это означает, что один товар может принадлежать только к одной категории (кроссовки adidas могут быть только "обувью", но не "перчатками" или "шапками"). В этот же момент, одна категория может принадлежать нескольким товарам (в "обувь" могут входить "кроссовки adidas", "кожаные сапоги", "кроссовки nike" и так далее).

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

SELECT
       p.id, p.name, p.description, p.price, 
       c.id as 'category_id', c.name as 'category_name', c.image as 'category_image'
 FROM
       product p, category c
 WHERE
       p.category_id = c.id
       AND
       c.id = N;

Где вместо N нам нужно будет подставить уникальный номер категории.

В соседних статьях вы можете найти информацию о других типах реляционных связей данных: многие ко многим, и один к одному. Если было полезно, можете поддержать лайком/комментарием/подпиской на мой образовательный YouTube-канал.

我在哪里可以设计数据库?

尝试使用新的可视化构造器,称为数据库设计。简单方便的界面使您能够以图形模型的可视化方式设计关系数据库,您可以链接来自不同表的字段,指示它们之间的关系。让我们看看它是什么样的:

观看预告片
Где можно спроектировать базу данных? В Database Design!

数据库设计应用程序中的模式可以稍后导出为SQL转储,通过链接下载。转储文件可用于在任何正常的SQL数据库管理系统(DBMS)中重新创建关系数据库的确切结构,如MySQL。您甚至不需要为此编写SQL查询代码!

在数据库设计应用程序中工作是一种乐趣!

适用于专业人士和学生,用于组织存储和分析,以及可视化数据库模型以满足他们的项目需求。

在数据库设计中,您可以从浏览器进行工作,无需下载或安装任何东西!

转到数据库设计构造器

更多文章
和项目新闻:

Как в SQL удалить данные из таблицы: запрос SQL DELETE FROM WHERE

Как в SQL удалить данные из таблицы: запрос SQL DELETE FROM WHERE

Примеры SQL запросов

Обучение SQL с примерами: как написать SQL команды, чтобы удалить строку из таблицы базы данных? Объясняю удаление строк SQL, как удалить запись SQL, простыми словами без воды. Запрос DELETE FROM WHERE это легко! Подойдёт для MySQL, PostgresQL, MS SQL, SQLite, Oracle, MariaDB и др. SQL СУБД. читать статью

Как в SQL изменить данные в записи таблицы: запрос SQL UPDATE

Как в SQL изменить данные в записи таблицы: запрос SQL UPDATE

Примеры SQL запросов

Обновление SQL записей, как написать SQL команды, чтобы изменить строку в таблице? Объясняю как редактировать данные в кортеже базы данных SQL, простыми словами без воды. Команда UPDATE SET это легко! Подойдёт для MySQL, PostgresQL, MS SQL, SQLite, Oracle, MariaDB и других SQL СУБД. читать статью

Как в SQL добавить строку в таблицу: запрос SQL INSERT INTO

Как в SQL добавить строку в таблицу: запрос SQL INSERT INTO

Примеры SQL запросов

Обучение SQL с примерами: как написать SQL команды, чтобы добавить данные в таблицу? Объясняю как вставить данные в таблицу базы данных, простыми словами без воды. Команда INSERT INTO — это легко! Подойдёт для MySQL, PostgresQL, MS SQL, SQLite, Oracle, MariaDB и других SQL СУБД. читать статью

Как в SQL получить данные из таблицы: запрос SQL SELECT FROM WHERE

Как в SQL получить данные из таблицы: запрос SQL SELECT FROM WHERE

Примеры SQL запросов

Обучение SQL с примерами: как написать SQL команды, чтобы получить данные из базы данных? Объясняю как достать информацию из базы данных, простыми словами без воды. Команда SELECT FROM WHERE это легко! Подойдёт для MySQL, PostgresQL, MS SQL, SQLite, Oracle, MariaDB и других SQL СУБД. читать статью

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

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

Новости проекта

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

Добавлено: удобный выбор таблицы и столбца для связи, возможность переключаться между тёмной и светлой темами, и 2FA-авторизация

Добавлено: удобный выбор таблицы и столбца для связи, возможность переключаться между тёмной и светлой темами, и 2FA-авторизация

Новости проекта

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

Реляционные базы данных это одна из составляющих практически любого IT-проекта. В чём суть баз данных? Для чего они нужны?

Реляционные базы данных это одна из составляющих практически любого IT-проекта. В чём суть баз данных? Для чего они нужны?

Основы баз данных

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

Основы проектирования БД: как создать связь «один к одному» (1:1) и когда нужен этот тип связи, простыми словами на примере

Основы проектирования БД: как создать связь «один к одному» (1:1) и когда нужен этот тип связи, простыми словами на примере

Основы баз данных

Уроки по реляционным базам данных, обучение базам данных онлайн. Как создать связь «многие ко многим» (М:М) и когда нужен этот тип связи. Изучение структуры реляционных баз данных с примерами SQL-запросов читать статью

Добавлены типы данных, расширенные настройки и экспорт FOREIGN, и переключение чувствительности мышки и тачпада

Добавлены типы данных, расширенные настройки и экспорт FOREIGN, и переключение чувствительности мышки и тачпада

Новости проекта

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

Основы проектирования БД: как создать связь «многие ко многим» (М:М) и когда нужен этот тип связи, простыми словами на примере

Основы проектирования БД: как создать связь «многие ко многим» (М:М) и когда нужен этот тип связи, простыми словами на примере

Основы баз данных

Уроки по реляционным базам данных, обучение базам данных онлайн. Как создать связь «многие ко многим» (М:М) и когда нужен этот тип связи. Изучение структуры реляционных баз данных с примерами SQL-запросов читать статью

Добавлены настройки общего доступа!

Добавлены настройки общего доступа!

Новости проекта

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

Основы проектирования БД: нормализация данных простыми словами, для чего нужны связи в реляционной БД, связь «один ко многим»

Основы проектирования БД: нормализация данных простыми словами, для чего нужны связи в реляционной БД, связь «один ко многим»

Основы баз данных

Уроки по реляционным базам данных, обучение базам данных онлайн. Связь one-to-many она же «‎один ко многим» (1:М), объясняю на примерах, простыми словами. читать статью

Не запускается MySQL: Ошибка MySQL Shutdown Unexpectedly

Не запускается MySQL: Ошибка MySQL Shutdown Unexpectedly

Восстановление БД

Всё работало как часы, и вдруг MySQL вылетает с ошибкой? Рассказываю как устранить проблему без потери данных читать статью