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

Всем привет. Подскажите пожалуйста. Создал такой запрос. SELECT oa."operator_session_id", oa."created_date_time" - LEAD(oa."created_date_time",

1) OVER (PARTITION BY "operator_session_id" ORDER BY oa."created_date_time" DESC) AS mins
FROM "operator_activity" AS oa
JOIN "operator_session" AS os ON os.operator_id IN (29, 30) AND os.ended = true
WHERE oa."type" IN ('OPEN')
AND oa."operator_session_id" = os.id
AND os.created_date_time BETWEEN '01.05.2022 00:00' ::TIMESTAMP AND '31.05.2022 00:00' ::TIMESTAMP
GROUP BY oa."operator_session_id", oa."created_date_time"

Таблицы:

CREATE TABLE "operator_activity"
(
"id" SERIAL8 NOT NULL,
"type" VARCHAR(50) NOT NULL,
"created_date_time" TIMESTAMP(6) NOT NULL DEFAULT CURRENT_TIMESTAMP(6),
"operator_session_id" INT8 NOT NULL,
PRIMARY KEY (id),
CONSTRAINT OPERATOR_ACTIVITY_OPERATOR_SESSION_FK FOREIGN KEY (operator_session_id) REFERENCES "operator_session" (id)
);

CREATE TABLE "operator_session"
(
"id" SERIAL8 NOT NULL,
"ended" BOOL NOT NULL DEFAULT false,
"work_time_end" TIME(6) NOT NULL,
"work_time_start" TIME(6) NOT NULL,
"created_date_time" TIMESTAMP(6) NOT NULL DEFAULT CURRENT_TIMESTAMP(6),
"updated_date_time" TIMESTAMP(6) NOT NULL DEFAULT CURRENT_TIMESTAMP(6),
"operator_id" INT8 NOT NULL,
PRIMARY KEY (id),
CONSTRAINT OPERATOR_SESSION_OPERATOR_FK FOREIGN KEY (operator_id) REFERENCES "operator" (id)
);

Мне нужно посчитать сколько оператор работал по факту. Рабочее время есть в operator_session и действия, которые он делал в operator_activity.

И вот нужно взять все его записи из operator_activity каждой сессии и высчитать разницу в минутах между строками. Но если разницу во времени между строками больше чем 30 минут не учитывать это время.

И вот проблема у меня в самом этом условии в 30 минут (хотя может и в самом запросе тоже беда).

Как прикрутить к запросу условие выборки строк для оконной функции?

2 ответов

5 просмотров

если брать для каждой строки последующую, то можно использовать lead и смотреть на разницу между текущей и следующей

Александр-Лемягов Автор вопроса
Kirill
если брать для каждой строки последующую, то можно...

Да. Я в запросе это прописал. Мне нужно добавить условие, что если разница текущей и следующей строки больше чем 30 минут - не учитывать эти строки в расчете потраченного времени

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

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

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
В дельфе нет никакого коробочного (без установки третьих либ) способа получить CallStack с расшифровкой отладочных символов?
notme
7
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
Карта сайта