В этом уроке мы познакомимся с основами работы с данными. Вы узнаете, как хранить информацию так, чтобы разработчикам было удобно работать с ней.
СУБД, базы данных и таблицы
Возьмем для примера интернет-магазин. В нем есть тысячи карточек товаров. В каждой карточке есть название, производитель, ключевые характеристики и цена.
Все это — данные, которые оформлены и представлены покупателю в наглядном виде:
Но разработчики интернет-магазина хранят данные о товарах совсем в другом виде. Разработчикам важно, чтобы с данными было удобно работать — например, менять.
Для удобной работы с данными существуют специальные программы — они называются СУБД (системы управления базами данных).
Для работы привычных нам приложений нужны разные по своей сущности данные. Например, интернет-магазин хранит не только информацию о товарах, но еще о клиентах и их покупках. Все эти данные объединяют в хранилища — в базы данных.
С базами данных было бы очень сложно работать, если бы они не имели конкретной продуманной структуры. Информацию о товарах, о клиентах и о покупках не смешивают в одну кучу, а сохраняют в разные таблицы.
Таким образом, каждая таблица хранит в себе данные, похожие по смыслу.
Например, в одной таблице мы храним информацию о товарах, в другой — о клиентах, и так далее.
Например, так может выглядеть таблица с данными о товарах — информации о клиентах здесь нет:
Сложность СУБД
Программы Postgresql, Mysql, Oracle, SQL Server являются СУБД — Системой Управления Базами Данных. СУБД не то же самое, что и база данных (БД). БД — это хранилище данных, у которых определенная внутренняя структура. Но кто-то должен ее обслуживать: создавать, обновлять, записывать в нее данные, выбирать их. Именно этим и занимается СУБД — специальная программа, которую необходимо установить на ту машину, где планируется размещать базу данных.
Когда компьютеры только появились, задачу хранения данных каждый решал по-своему. Самый простой способ хранить данные — положить их в файл. Но тогда неизбежно встанут вопросы:
-
Как потом найти эти данные?
-
А если разные данные имеют разную структуру и разный размер?
-
А что, если данные понадобятся нескольким пользователям одновременно?
-
А что, если во время обновления произойдет сбой?
-
А если данных станет настолько много, что они не поместятся в один файл?
Именно из-за этих вопросов разработка систем хранения — очень сложная и затратная история. Инженеры довольно быстро поняли, что базами данных должна заниматься специализированная программа, функционирующая независимо от софта, который они разрабатывают.
СУБД — невероятно сложные программы, к которым предъявляются практически максимальные требования по надежности, скорости работы и эффективности. Неспроста считается, что если СУБД меньше 10 лет, то это слишком молодой продукт для использования в серьезных приложениях.
Как устроены СУБД
СУБД реализуется как клиент-серверное приложение:
-
Сервером выступает сама СУБД — она управляет файлами баз данных, принимает запросы от клиентов и выполняет их команды
-
Клиентом считается любое приложение, желающее взаимодействовать с базой данных.
Клиентские приложения могут быть разнообразны по форме:
-
Текстовая утилита
-
Графическое приложение
-
Веб-сервер, использующий базу данных для отображения веб-страниц
-
Специализированный инструмент для обслуживания баз данных
Сервер в такой архитектуре спроектирован так, что он может работать с большим количеством одновременных подключений от разных клиентов. Подобная схема имеет большое значение в реальной жизни. Как правило, база данных используется большим количеством пользователей одновременно.
Иногда сервер и клиент располагаются на одной машине. Это удобно во время разработки:
Выводы
В этом уроке мы познакомились с СУБД, базами данных и таблицами. Повторим ключевые выводы:
-
Похожие по смыслу данные хранятся в отдельных таблицах
-
Таблицы с данными об одном проекте объединяют в базу данных. Другими словами, база данных — это просто набор таблиц
-
Чтобы удобно работать с базами данных, разработчики используют СУБД.
-
Базы данных реализуют клиент-серверную архитектуру. Для работы с базами используют специальные программы.
Теперь вы знаете, что база данных и СУБД — это не одно и то же. Далее мы более подробно поговорим о таблицах в базах данных и какие они имеют особенности.
Остались вопросы? Задайте их в разделе «Обсуждение»
Вам ответят команда поддержки Хекслета или другие студенты