|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
|
Статистика пользователей по возрасту10.06.2010, 03:12. Показов 1765. Ответов 15
Метки нет (Все метки)
Доброго времени суток, хотел бы сделать статустику пользователей по возросту. К примеру:
до 18 лет - от 18 до 23 - -----||----- Проблема в том, что в поле дата рождения записана как "1.1.1950". Вопрос вот в чем, как обработать базу так, чтобы он брал из неё только год, а не день, месяц и год. Просто точная статистика не нужна, нужна примерная. На теории это делается через split как я понял, вытаскивается год и минусуется из текущего, а дальше через if. Но как split прикрутить к запросу и после этого ещё сложить полученные результаты и предоставить не могу понять Помогите пожалуйста...
0
|
|
| 10.06.2010, 03:12 | |
|
Ответы с готовыми решениями:
15
Статистика пользователей - как идентифицировать пользователей с одинаковыми именами Как провести сортировку после выбора данных пользователей по возрасту? Повседневная статистика пользователей |
|
Почетный модератор
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
|
||||||
| 10.06.2010, 08:31 | ||||||
|
Можно использовать YEAR(<поле с датой>)
Или лучше использовать DATE_ADD(<поле с датой>,INTERVAL <сколько лет> YEAR)
1
|
||||||
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
||||||
| 10.06.2010, 21:30 [ТС] | ||||||
|
Спасибо. А если сделать статистику в режиме он-лайн? тоесть на данный момент зарегестрировано столько-то пользователей до 18, столько то от 18 до 23, от 23 и т.д.?
я представляю это примерно так:
0
|
||||||
|
Почетный модератор
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
|
||||||||
| 10.06.2010, 21:43 | ||||||||
1
|
||||||||
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
|
| 10.06.2010, 21:47 [ТС] | |
|
да, именно varchar. Просто когда делал сайт, не задумывался и записывал для более легкого вывода. Спасибо.
Не заметил, так тут не отделено 3 значение
0
|
|
|
Почетный модератор
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
|
|||||||||||
| 10.06.2010, 22:16 | |||||||||||
|
Можешь переделать всё в DATE... выполни по очереди 3 такие запроса
1
|
|||||||||||
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
||||||
| 10.06.2010, 22:46 [ТС] | ||||||
|
В таком случае получилось, что дата отображается как год, месяц и день, правильно? или год день и месяц?
В общем получилось Остался вопрос, на сервере 5 человек, сделал так:
До 18: 5 От 18 до 23: 5 От 23 до 30: 4 От 30 до 50: 4 После 50: 0 Хотя до 18 Нет пользователей
0
|
||||||
|
|
|||||||
| 10.06.2010, 23:15 | |||||||
![]() А по поводу запроса, попробуйте так:
0
|
|||||||
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
|||||||||||
| 10.06.2010, 23:21 [ТС] | |||||||||||
|
Хотя я сделал. Сделал запрос наобщее кол-во пользователей и вычел из него получившиеся. Спасибо
![]() romchiksoad, В твоем случае он показывает вот так: До 18: 5 От 18 до 23: 5 От 23 до 30: 5 От 30 до 50: 5 После 50: 5 Я сделал вот так:
А если ещё сделать в % соотношении то так:
Соотношение в %: До 18: 0% От 18 до 23: 0% От 23 до 30: 20% От 30 до 50: 20% После 50: 100% Соотношение в кол-ве: До 18: 0 От 18 до 23: 0 От 23 до 30: 1 От 30 до 50: 1 После 50: 5 Все как я и хотел. Спасибо
0
|
|||||||||||
|
|
|
| 10.06.2010, 23:25 | |
|
acupation, жестко
тогда надо еще "курить" по этому вопросу
0
|
|
|
Почетный модератор
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
|
|
| 10.06.2010, 23:25 | |
|
Наверное, знак надо не "больше", а "меньше"
....WHERE DATE_SUB(NOW(),INTERVAL 18 YEAR)<birth
0
|
|
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
|
| 10.06.2010, 23:26 [ТС] | |
|
хм, хотя я заметил, что у меня статистика не правильная)
0
|
|
|
Почетный модератор
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
|
|||||||||||
| 10.06.2010, 23:28 | |||||||||||
|
И опять же не надо все строки выдергивать из таблицы, только для того, что бы их число посмотреть. Это очень не оптимально.
Если у тебя таблица MyISAM, то можно
0
|
|||||||||||
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
|
| 10.06.2010, 23:38 [ТС] | |
|
MyISAM у меня. Я тут посмотрел... Он промежуток получается не счтает от и до, а берет чисто до.
До 18: 0 От 18 до 23: 0 От 23 до 30: 1 От 30 до 50: 1 После 50: 5 Как изменить интеррвал? через and?
0
|
|
|
Почетный модератор
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
|
||||||
| 10.06.2010, 23:44 | ||||||
|
Можно построить немного по другому запрос:
Проблема будет только в том, случае, если кому-то в этот день исполнилось 18 лет (или любое другое пограничное количество лет)... тогда он отнесёт его к двум категориям.
1
|
||||||
|
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
|
||||||
| 11.06.2010, 00:29 [ТС] | ||||||
0
|
||||||
| 11.06.2010, 00:29 | |
|
Помогаю со студенческими работами здесь
16
Статистика пользователей: показывать, сколько пользователей работают сейчас в программе статистика пользователей и роботов Статистика Пользователей PHP Статистика времени работы пользователей Статистика работы пользователей с базой Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|