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

Всем привет! Есть ли кто-то, кто шарит в оптимизации запросов?

Напишите, пожалуйста.
Кратко:
У меня в таблице id (uuid), asset_id (uuid), date_time (timestamp) и десяток NUMERIC колонок (spin_gen, spin_clr, etc). date_time ежечасный (24 записи на каждый день).
Я делаю расчёт SMA, Cumulative sum, sum, avg для каждого asset_id (штук 70). Если я высчитываю по дням, то за 1.8сек (второй за 0.8) отрабатывает, если считаю всё по часам, то за 7.3 секунды.

Пример запроса (колнки spin_gen, spin_clr numeric. Таких у меня 10 колонок.
SELECT 'day' AS VIEW, asset_id, _assets.NAME AS asset_name, _assets.company_name AS asset_owner, to_char( date_view, 'YYYY-MM-DD HH24:MI:SS' ) AS DATE, checksum :: NUMERIC, json_build_object (
'avg',spin_avg,
'sum',spin_sum,
'cusum',COALESCE ( SUM ( spin_sum ) OVER ( PARTITION BY asset_id ORDER BY date_view ASC ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW ), 0 )
) AS spin

FROM (
SELECT date_trunc('hour', date_time) as date_view, COUNT ( date_time ) AS checksum, asset_id, AVG ( spin_clr + spin_gen ) AS spin_avg, SUM ( spin_clr + spin_gen ) AS spin_sum
FROM cmy_table
WHERE date_time BETWEEN '2022-01-01T00:00:00' AND '2022-12-31T23:59:00' AND asset_id IN ( SELECT ID FROM assets )
GROUP BY date_view, asset_id
-- ORDER BY
-- date_view
) T INNER JOIN assets _assets ON _assets.ID IN ( T.asset_id )

P.S. можно лично, за вознаграждение)

4 ответов

18 просмотров

что хотите улучшить? что не устраивает?

Me👀- Автор вопроса
central hardware
что хотите улучшить? что не устраивает?

Я хочу понять, правильно вообще ход мысли у меня или есть лучше варианты (быстрее)

https://t.me/pgsql/303899

Me👀- Автор вопроса
Ilya Anfimov
https://t.me/pgsql/303899

v13.3, https://explain.tensor.ru/archive/explain/560872bf504d3cdeacea883f8ccdaf8a:0:2022-06-11

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

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

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Мне тут приспичило встроить в программу форматировние текста SQL, расставить переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых сл...
Sergey Bodrov
11
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Добрый день. Опять снова хочу обратиться к вам за помощью. После создания проэкта stack new, lazy.nvim + nvim-lspconfig/haskell-tools + hlint, ormolu из mason + hls из ghcup ...
Nannk
8
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
Карта сайта