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

Привет. Есть колонка date date() (yyyy-mm-dd) От пользователя прилетают две строки

в формате 'Mon yy'.
Первая строка - первый месяц, вторая - второй. Нужно написать запрос, который будет выводить данные за период между первой и второй датой.
Сейчас работает такой запрос:
select summ, date from income
where date_part('year', date) >= date_part('year', to_date(%s, 'Mon yy')) and
date_part('month', date) >= date_part('month', to_date(%s, 'Mon yy')) and
date_part('year', date) <= date_part('year', to_date(%s, 'Mon yy')) and
date_part('month', date) <= date_part('month', to_date(%s, 'Mon yy'));
но выглядит он дико здоровым.
Подскажите, как можно сделать проще?

4 ответов

7 просмотров

Почему бы данные пользователя не привести к типу date ? Тогда будет просто: WHERE date BETWEEN 'mon yy' and 'mon yy' ?

A101- Автор вопроса
Andrei Ilinskii
Почему бы данные пользователя не привести к типу d...

Если приводить, например, 'Oct 21' к типу date, получится 2021-10-01. Если пользователь выбирает два раза 'Oct 21', поиск будет между 2021-10-1 и 2021-10-1, что не даст нужного результата. Также и с 'Oct 21' и 'Nov 21'. Поэтому я и писал функции date_part, выделяя, что искать нужно именно между годом, месяцем первого запроса и годом, месяцем второго.

A101
Если приводить, например, 'Oct 21' к типу date, по...

Ну так нормально же. Вам нужно первую дату включительно, а вторую не включительно и ко второй прибавлять месяц. То есть пользователь два раза вбил Oct 21, то запрос: WHERE date >= '2021-10-01' AND date < (2021-10-01 + INTERVAL '1 month')

A101- Автор вопроса

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

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

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
Есть сайт. Там была древняя версия эво. Стоял плагин, который каждый коммент в Jot делал отдельной страницей. После обновления все слетело, теперь старница открывается отдельн...
Artem
1
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
Добрый день. А shovel'ы можно как-то сконфигурировать в definitions.json? Пробовал что-то вроде: { "users": [ { "name": "agent", "password_hash": "RBCbTzQd...
Aleksey
1
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Карта сайта