
eleday
Канал про Python, IT, программирование и нейросети
Статистика канала
SELECT name FROM users WHERE id = 42;
А чтобы добавить красную лампу
INSERT INTO devices (type, color) VALUES ('lamp', 'red');
- Схема
В SQL-базах данные сохраняются в таблицы. В каждой таблице есть колонки — поля с определённым типом и строки — записи об отдельных объектах, например:
Таблица users
id name age admin
1 Вася 45 false
2 Петя 67 true
- Лезем внутрь
Чтобы разобраться с тем, как работает СУБД, проследим путь от SQL-запроса до возвращенных данных
1. Прием запроса, парсинг
СУБД принимает SQL-запрос от пользователя, проверяет его на синтаксические ошибки и из набора букв преобразует в AST (Abstract Syntax Tree)
Когда-то подробно коснёмся этой темы
2. Семантический анализ
Запрос сопоставляется с реальной базой. Проверяется, существуют ли запрашиваемые таблицы, совпадают ли типы данных
3. Планирование
СУБД определяет оптимальный план выполнения задачи: генерирует различные варианты, оценивает их сложность и выбирает лучший
4. Исполнение
Каждый узел плана — оператор, который вызывает следующий. Например:
- Взять строку из таблицы
- Проверить, выполняется ли условие (id = 42)
- Добавить строку в результат, если выполняется
- Повторить для следующей строки
5. Хранение данных
Перед записью данные сериализуются в бинарный формат и сохраняются на диск блоками по 4–16 КБ — страницами
6. Индексы
Специальная структура — индекс — позволяет осуществлять более быстрый поиск. Он хранит отсортированные ключи и соответствующие указатели на реальные данные. Для поиска по проиндексированному полю не нужно перебирать всю таблицу, можно просто взять уже сохраненный указатель
Если индекса нет, СУБД выполняет полный перебор таблицы, проверяя каждую строку
7. Кэширование
Диск медленный, поэтому СУБД хранит часто используемые страницы в оперативной памяти, что позволяет реже читать диск и ускоряет работу
8. Транзакции
Транзакция — группа операций, которые должны выполниться вместе
Обычно СУБД следуют наборам требований ACID:
- Atomicity (атомарность) — транзакция рассматривается как единое целое: либо выполнится все, либо ничего
- Consistency (согласованность) — исполнение транзакции приводит систему в корректное состояние
- Isolation (изоляция) — транзакции, исполняющиеся в одно время не должны мешать друг другу
- Durability (устойчивость) — после успешного выполнения транзакции ее результат сохраняется даже при сбое системы
9. Журналирование
Перед тем, как выполнить действие, СУБД записывает его в журнал. Это позволяет восстанавливать данные в случае сбоя
10. Конкурентность
Может случится такое, что несколько транзакций одновременно обращаются к одним и тем же данным. Чтобы избежать конфликтов, используются блокировки и MVCC (версионность данных)
После обработки данные возвращаются клиенту. В случае, если возвращать ничего не требуется (при добавлении, изменении или удалении записей), возвращается статус: успешно или нет
Итоговая схема от запроса до данных:
- SQL
- парсинг
- AST
- план выполнения
- исполнение
- индексы / диск
- результат
Что думаете про такой формат больших постов? На какие темы хотели бы видеть ещё?
@eledayОтзывы канала
всего 9 отзывов
- Добавлен: Сначала новые
- Добавлен: Сначала старые
- Оценка: По убыванию
- Оценка: По возрастанию
Каталог Телеграм-каналов для нативных размещений
eleday — это Telegam канал в категории «Интернет технологии», который предлагает эффективные форматы для размещения рекламных постов в Телеграмме. Количество подписчиков канала в 4.9K и качественный контент помогают брендам привлекать внимание аудитории и увеличивать охват. Рейтинг канала составляет 28.1, количество отзывов – 9, со средней оценкой 5.0.
Вы можете запустить рекламную кампанию через сервис Telega.in, выбрав удобный формат размещения. Платформа обеспечивает прозрачные условия сотрудничества и предоставляет детальную аналитику. Стоимость размещения составляет 1118.88 ₽, а за 39 выполненных заявок канал зарекомендовал себя как надежный партнер для рекламы в TG. Размещайте интеграции уже сегодня и привлекайте новых клиентов вместе с Telega.in!
Вы снова сможете добавить каналы в корзину из каталога
Комментарий