Назад к вопросам
МВидео
Middle+
3
Таблица с (id PRIMARY KEY, data JSON) — индекс PostgreSQL вполне хороший для поиска по ключу?
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Индекс PostgreSQL на столбце с типом JSON (или JSONB) может быть эффективным для поиска по ключу, но зависит от типа индекса и структуры данных.
Если у вас таблица с колонкой data JSON, то для быстрого поиска по ключам внутри JSON стоит использовать тип JSONB и создавать GIN-индекс:
CREATE INDEX idx_data_gin ON table_name USING GIN (data jsonb_path_ops);
Или просто:
CREATE INDEX idx_data_gin ON table_name USING GIN (data);
Это позволит эффективно выполнять запросы с операторами @>, например:
SELECT * FROM table_name WHERE data @> '{"key": "value"}';
Если же используется просто JSON без индексации, поиск будет медленным, так как будет сканироваться вся таблица.
Таким образом, обычный индекс по id не помогает для поиска по ключам внутри JSON. Для этого нужен специализированный GIN-индекс на JSONB.