я как сделать чисто в sql задумался:
Есть таблица: uid login date_enter
Ну, грубо говоря вот такая.
Надо считать уникальные заходы в каждый день:
Грубо говоря, в понедельник было 10 человек, во вторник уже 15, но 10 из них были вчера == 5 уникальных, и т.д., по накатанной.
Проблема, собственно сделать силами SQL, скриптом то понятно. Но и сложности прибавляет не просто сравнивать со вчерашним, а со вчерашними:
То есть в пятницу, надо проверять с теми уникальными которые зашли в четверг, среду, вторник, понедельник.
Есть идеи, как сделать на sql ?
оконные функции
уточню google: нарастающий итог оконные функции
Спасибо мил человек, но хотелось бы конкретики. О них я знаю... Ипать, а че в пол минуты поставили таймаут на ответ :?
Не совсем то: глянул статью на хабре, это про накатанный итог, а мне нужна именно уникальность. id людишек, которых не было раньше, изо дня в день, только новые записи, грубо говоря.
а еще же можно же просто сгруппировать по min(date_enter)
а вы покажите исходные данные и ваше видение - что хотите получить в итоге а то на словах нифига не понятно
боюсь, что не всё так просто, но передал, спасибо!
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
Момент. В пнд зашли: 1, 2, 3 Во вт зашли: 2, 4, 5 В ср зашли: 1, 2, 5, 6, 7 и т.д. И как я понял, это сравнение идёт по id пользователя. И в итоге должно выйти: пн — 1, 2, 3 вт — 4, 5 ср — 6, 7
select first_date, array_agg(uid) from (select uid, min(date_enter) as first_date from ... group by 1) t;
а как именно в БД записано, что в пн зашли 1, 2, 3?
Мы сейчас отталкиваемся от того, что есть дата (надеюсь это так). Но я хочу рассмотреть вариант, где совсем всё плохо, и есть только номер дня, в году, или в неделю, я хз, нету инфы откуда порядковый номер, и человеческая id
Нету данных у меня: просто спросили можно ли как-то бахнуть в принципе, рассказал как с помощью яп, а потом спросили, а можно ли силами 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 без претензии на оптимизацию
Если можно, в моношрифт пжлс) Я не совсем понимаю, что за логин с апострофами
Обсуждают сегодня