Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
18.11.2021, 10:43
|
|||
---|---|---|---|
|
|||
SUM / IF / CASE WHEN... |
|||
#18+
Добрые люди, помогите пжста разобраться с агрегатными функциями. У меня есть таблица (deals) с датой (created_at) названием товара (a.name) и кол-вом (amount). Мне необходимо сделать запрос и вытащить сколько тавара было завезено за последние 10 часов / 20 часов / 30 часов. я никак не могу понять как выставить SUM amount за последние 10 / 20 и 30 часов в created_at если выбрать только 10 часов то это просто SELECT a.name, SUM(amount) as 10hrs FROM deals where created_at >= now() - INTERVAL 10 HOUR GROUP BY a.nme но мне надо, чтоб в одном запросе вытащить и 20 часов и 30 часов. Результат должен быть похож на это a.name | 10hrs | 20hrs | 30hrs ban | 10 | 12 | 15 tilt | 2 | 5 | 10 ... |
|||
:
Нравится:
Не нравится:
|
|||
|
18.11.2021, 12:29
|
|||
---|---|---|---|
SUM / IF / CASE WHEN... |
|||
#18+
Используй условную агрегацию: Код: sql 1. 2. 3. 4. 5. 6. 7.
... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/search_topic.php?author=%D0%98%D0%B2%D0%B0%D0%BD+%D0%A1%D0%B0%D0%BB%D0%BE%D0%B2&author_mode=last_posts&do_search=1]: |
0ms |
get settings: |
12ms |
get forum list: |
14ms |
get settings: |
11ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
164ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
38ms |
get tp. blocked users: |
1ms |
others: | 439ms |
total: | 714ms |
0 / 0 |