Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: json, jsonb

Чем отличаются типы данных JSON и JSONB в PostgreSQL?

Вопрос проверяет понимание хранения и обработки JSON-данных в PostgreSQL и умение выбирать подходящий тип.

Короткий ответ

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

Длинный ответ

Общая идея типов JSON в PostgreSQL

PostgreSQL поддерживает два типа для хранения JSON:

  1. JSON

  2. JSONB

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

Как хранится JSON

Определение:
JSON хранится как текст, практически без обработки.

Особенности:

  1. Сохраняется исходный формат

  2. Сохраняется порядок ключей

  3. Каждое чтение требует повторного разбора

Пример:

INSERT INTO events(data)
VALUES ('{"a":1,"b":2}');

При запросе PostgreSQL заново парсит строку.

Как хранится JSONB

Определение:
JSONB хранится в бинарном формате, разобранном и оптимизированном для поиска.

Особенности:

  1. Порядок ключей не сохраняется

  2. Дубликаты ключей удаляются

  3. Быстрее поиск и фильтрация

Пример:

INSERT INTO events(data)
VALUES ('{"a":1,"b":2}'::jsonb);

Индексы

Ключевое преимущество JSONB — возможность индексирования.

Пример:

CREATE INDEX idx_events_data
ON events USING GIN (data);

Это позволяет быстро искать:

SELECT * FROM events
WHERE data @> '{"a":1}';

С JSON такие индексы не работают эффективно.

Производительность

На практике:

  1. Вставка JSON немного быстрее

  2. Поиск и фильтрация JSONB значительно быстрее

  3. JSONB занимает чуть больше CPU при записи, но выигрывает при чтении

Когда использовать JSON

Редкие случаи:

  1. Важно сохранить точный формат документа

  2. Данные почти не читаются и не фильтруются

Когда использовать JSONB

Чаще всего:

  1. Фильтрация по полям

  2. Индексы

  3. Аналитические запросы

  4. Метаданные

Вывод

JSON — текстовое хранение для совместимости и точности формата.
JSONB — оптимизированное бинарное хранение для поиска, индексов и большинства практических задач, поэтому в реальных системах обычно выбирают именно его.

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    5

  • Сложность:

    6

Навыки

  • Postgres

    Postgres

Ключевые слова

#json

#jsonb

Подпишись на Python Developer в телеграм

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.