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

День добрый люди людные, есть задача, вернее меня спросили, а

я как сделать чисто в sql задумался:

Есть таблица: uid login date_enter
Ну, грубо говоря вот такая.

Надо считать уникальные заходы в каждый день:
Грубо говоря, в понедельник было 10 человек, во вторник уже 15, но 10 из них были вчера == 5 уникальных, и т.д., по накатанной.
Проблема, собственно сделать силами SQL, скриптом то понятно. Но и сложности прибавляет не просто сравнивать со вчерашним, а со вчерашними:
То есть в пятницу, надо проверять с теми уникальными которые зашли в четверг, среду, вторник, понедельник.

Есть идеи, как сделать на sql ?

17 ответов

5 просмотров

оконные функции

уточню google: нарастающий итог оконные функции

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Rainbow Keeper
оконные функции

Спасибо мил человек, но хотелось бы конкретики. О них я знаю... Ипать, а че в пол минуты поставили таймаут на ответ :?

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Альберт Степанцев
уточню google: нарастающий итог оконные функции

Не совсем то: глянул статью на хабре, это про накатанный итог, а мне нужна именно уникальность. id людишек, которых не было раньше, изо дня в день, только новые записи, грубо говоря.

а еще же можно же просто сгруппировать по min(date_enter)

Mʀ. Sʜɪsʜᴋɪɴᅠ [ᴇʟ]
Не совсем то: глянул статью на хабре, это про нака...

а вы покажите исходные данные и ваше видение - что хотите получить в итоге а то на словах нифига не понятно

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Rainbow Keeper
а еще же можно же просто сгруппировать по min(date...

боюсь, что не всё так просто, но передал, спасибо!

Mʀ. Sʜɪsʜᴋɪɴᅠ [ᴇʟ]
боюсь, что не всё так просто, но передал, спасибо!

select first_date, count(*) from (select uid, min(date_enter) as first_date ну вы скажите что тут не так) раз так

если вам надо просто список select login, date_enterrr::date, count(*) from tabl group by date_enter::date ,login

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Альберт Степанцев
а вы покажите исходные данные и ваше видение - что...

Момент. В пнд зашли: 1, 2, 3 Во вт зашли: 2, 4, 5 В ср зашли: 1, 2, 5, 6, 7 и т.д. И как я понял, это сравнение идёт по id пользователя. И в итоге должно выйти: пн — 1, 2, 3 вт — 4, 5 ср — 6, 7

Mʀ. Sʜɪsʜᴋɪɴᅠ [ᴇʟ]
Момент. В пнд зашли: 1, 2, 3 Во вт зашли: 2, 4, 5...

select first_date, array_agg(uid) from (select uid, min(date_enter) as first_date from ... group by 1) t;

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Rainbow Keeper
select first_date, array_agg(uid) from (select uid...

Мы сейчас отталкиваемся от того, что есть дата (надеюсь это так). Но я хочу рассмотреть вариант, где совсем всё плохо, и есть только номер дня, в году, или в неделю, я хз, нету инфы откуда порядковый номер, и человеческая id

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Альберт Степанцев
а как именно в БД записано, что в пн зашли 1, 2, 3...

Нету данных у меня: просто спросили можно ли как-то бахнуть в принципе, рассказал как с помощью яп, а потом спросили, а можно ли силами sql только сделать с оконными функциями.

select date_enter, string_agg(login,',') as login_LIST from( select date_enter ,login from (values ('1','Vasy','01-01-2021'),('2','Vasy','02-01-2021'::date),('3','Vasy','03-01-2021'::date),('4','Oly','02-01-2021'::date),('5','Oly','03-01-2021'::date),('6','Oly','03-01-2021'::date) ) as T (uud,login, date_enter ) group by date_enter::date ,login) tt group by date_enter::date без претензии на оптимизацию

Mʀ. Sʜɪsʜᴋɪɴᅠ-[ᴇʟ] Автор вопроса
Геннадий Золотарев
select date_enter, string_agg(login,',') as login...

Если можно, в моношрифт пжлс) Я не совсем понимаю, что за логин с апострофами

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

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

Сообщение* в закодированном виде. То есть, просто сделать 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
Карта сайта