172 похожих чатов

Привет, изучаю pgsql, подскажите, насколько этот query оптимальный? Можно ли

как-то убрать повторы now()?
Этим query хочу вытащить актуальные (по отношению к now()) строки product_prices:
SELECT * FROM public.product_prices
WHERE tstzrange(valid_at) && tstzrange(now(), now(), '[]')

12 ответов

12 просмотров

SELECT * FROM public.product_prices WHERE tstzrange(valid_at) = now() ???

mikurei- Автор вопроса
Андрей Никитин
SELECT * FROM public.product_prices WHERE tstzrang...

возвращает ошибку ERROR: operator does not exist: tstzrange = timestamp with time zone LINE 2: WHERE tstzrange(valid_at) = now() ^ HINT: No operator matches the given name and argument types. You might need to add explicit type casts.

valid_at. какого типа?

mikurei- Автор вопроса
mikurei
возвращает ошибку ERROR: operator does not exist...

SELECT * FROM public.product_prices WHERE tstzrange(valid_at) @> now() А так?

а зачем с датой+временем работать через FTS?

mikurei- Автор вопроса
Виктор Егоров
а зачем с датой+временем работать через FTS?

извините, не совсем понимаю, что такое FTS? 😅 Просто есть таблица, в которой хранятся предложения для некоторого продукта, и у предложений есть срок их действия. Хочу извлечь предложения, актуальные на текущее время.

Виктор Егоров
я ошибся, не FTS это…

Да это много чего (в т.ч. и FTS): List of operators Schema | Name | Left arg type | Right arg type | Result type | Description ------------+------+---------------+----------------+-------------+---------------------------------- pg_catalog | && | anyarray | anyarray | boolean | overlaps pg_catalog | && | anymultirange | anymultirange | boolean | overlaps pg_catalog | && | anymultirange | anyrange | boolean | overlaps pg_catalog | && | anyrange | anymultirange | boolean | overlaps pg_catalog | && | anyrange | anyrange | boolean | overlaps pg_catalog | && | box | box | boolean | overlaps pg_catalog | && | circle | circle | boolean | overlaps pg_catalog | && | inet | inet | boolean | overlaps (is subnet or supernet) pg_catalog | && | polygon | polygon | boolean | overlaps pg_catalog | && | tsquery | tsquery | tsquery | AND-concatenate

Смотря по каким критэриям оптимизируете.

mikurei- Автор вопроса
Ilya Anfimov
Смотря по каким критэриям оптимизируете.

В плане читабельности запроса: интуиция подсказала, что первоначальный вариант не самый хороший) @ZiBnv подсказал классный и короткий query

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Открыл свой двухкилобайтный экзешник в x32dbg, а тут какая-то хрень. Смущает кнопка "выполнить до пользовательского кода", а что ещё может быть в файле помимо него ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
11
Мне были интересны дишные хаки и я нашёл любопытный способ на форуме через __traits, что-то вроде int delegate(int) fac = (int n) => n == 0 ? 1 : n * __traits(parent, {})(n - ...
Constantin F.
1
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
14
Вопрос тем кто смотрит видео и слушает подкасты - как вы потом ищете нужную вам информацию? Вот статью я прочитал, потом могу искать нужную мне часть банальным поиском. Пропус...
Aleksandr Druzhinin
4
Ребят, если кто в курсе - скажите, а в загранке такое же засилье маркетплейсов? или там простые сермяжные интернет-магазины живут попроще?
Андрей [aharito] Харитонов
14
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
Карта сайта