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

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

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

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

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

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

17 ответов

17 просмотров

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

уточню 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...

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта