Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
6 / 6 / 6
Регистрация: 15.02.2015
Сообщений: 53

Выборка за каждую неделю

17.09.2015, 14:36. Показов 2348. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте товарищи!
Есть бд users = id | name | date | level | stat1 | stat2 где date типа DATE, level от 1 до 12 и stat1,stat2 INT.
Необходимо сделать выборку по максимальным статам по каждому level, при этом если за календарную неделю есть несколько записей у юзера учитывать только последнюю.

Последние значения для конкрентого юзера по неделям получаю так
SQL
1
SELECT * FROM (SELECT name, DATE, level, date_format(DATE, '%u') AS d FROM `users` WHERE name='name' ORDER BY DATE DESC ) AS week GROUP BY d ORDER BY DATE ASC
А необходимо найти максимальное значение stat1 например, среди всех юзеров учитывая level и календарную неделю.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.09.2015, 14:36
Ответы с готовыми решениями:

Как выполнять запрос к бд каждую неделю?
Как выполнять запрос к бд через PHP каждую неделю?

Бэкап файлов каждую неделю
Здравствуйте, стоит windpws 10 enterprise ltsb на сервере с 2-мя дисками. Надо что бы предположим раз в неделю из 1-й папки все файлы...

Запись в файл каждую неделю
Как сделать что бы в воскресенье (например) ночью записывало в файл текст который мне нужен. Вот что я набросал <?PHP $c =...

5
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
17.09.2015, 21:49
Последнюю дату недели можно поймать, например, так:
Отобрать все строки, для которых в этой же таблице нет строк с тем же юзером, тем же годом, той же неделей, и датой больше чем в отобранной строке

Добавлено через 7 часов 3 минуты
Дальше, когда отобраны только последние дни в каждой из недель, можно обычным образом группировать по LEVEL и считать максимумы и прочую белиберду (среди отобранного по фильтру)
0
6 / 6 / 6
Регистрация: 15.02.2015
Сообщений: 53
17.09.2015, 22:13  [ТС]
Цитата Сообщение от cygapb-007 Посмотреть сообщение
Дальше, когда отобраны только последние дни в каждой из недель
Необязательно будут все записи юзеров в последний день недели, может быть и посередине и в начале всего одна запись об одном юзере
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
18.09.2015, 08:59
blackhat, от же ж...
По фильтру, в каждой из недель для каждого из юзеров нет строк с более поздней датой. А первый день недели или последний - это не обсуждалось
0
6 / 6 / 6
Регистрация: 15.02.2015
Сообщений: 53
18.09.2015, 14:34  [ТС]
SQL
1
2
3
4
5
6
7
SELECT yw, level, MAX(greatest(stat1, stat2)) stat 
    FROM 
        (SELECT level, stat1, stat2, yearweek('date',1) yw
            FROM users 
            ORDER BY level, DATE DESC, id
        ) u
    GROUP BY level, yw
Результат получается таким запросом.
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
18.09.2015, 15:56
MySQL
1
2
3
4
5
6
7
8
9
select yearweek(u.`date`)yw, level, MAX(greatest(stat1, stat2)) stat 
from users u
where not exists(
  select *
  from users e
  where e.id=u.id and yearweek(e.`date`)=yearweek(u.`date`)
    and e.`date`>u.`date`
  )
group by level, yw
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.09.2015, 15:56
Помогаю со студенческими работами здесь

Вылетает ОЗУ, каждую неделю
Всем привет. вылетает ОЗУ, каждую неделю. менял мамку и память, тестил прогой s&m ошибок не было, через неделю комп виснет и помогает...

Выборка за неделю
Здравствуйте. Подскажите если я вывожу новости за сегодня так: WHERE DATE(`news`.`date`) = CURDATE() как мне вывести новости за...

ASUS K52J виснет каждую неделю
Подскажите мне, что делать с ноутбуком в такой ситуации: Купила месяц назад себе ноут ASUS K52J. В магазине мне работники установили...

Определить средний курс доллара за каждую неделю месяца
В массиве храниться информация о курсе доллара за каждый день месяца.Определить средний курс доллара за каждую неделю месяца.

Выборка из базы на неделю средствами php
Привет ! Помогите советом ! Нужно сделать выборку записей из таблицы mysql где есть поле date отдельно на текущую неделю на прошлую и на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru