Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для Pavel Rem
11 / 11 / 2
Регистрация: 15.07.2016
Сообщений: 132

Задачка. Пользователи онлайн

29.09.2017, 22:32. Показов 1094. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пользователь может быть 2-ух типов. (Тип 1, Тип 2).
Пользователь типа-1 при регистрации на сайте выбирает из списка (назовем его "Цвет") несколько пунктов.
Пример:
Список 1.зеленый, 2.черный, 3.красный 4.синий ....
Пользователь может выбрать один или больше вариантов.

Есть форма для пользователей типа-2 в которой есть листбокс.
HTML5
1
2
3
4
<select>
  <option>Пункт 1</option>
  <option>Пункт 2</option>
</select>
Нужно заполнить этот листбокс по следующим правилам:
Выбрать из онлайн пользователей, тех, у которых тип-1,
получить для каждого выбранного пользователя его личный список "Цвет"(который он выбрал при регистрации),
и заполнить листбокс только теми пунктами, которые выбраны у этих (онлайн) пользователей.(Они не должны дублироваться)
А также вывести остальные пункты из списка "Цвет" но поставить им атрибут (disabled).

Другими словами, нужно заполнить листбокс списком "Цвет", но активными полями оставить только те, которые есть у онлайн пользователей типа (Тип-1).

Вход на сайт выглядит так:
PHP
1
2
3
4
5
6
7
//...
//...
$user = //манипуляции с бд
 if ($user) {
$_SESSION['user_id'] = $user['id'];
$_SESSION['user_type'] = $user['type'];
}
Вопрос 1: как получить список онлайн пользователей? Можно их вытянуть из сессии?
Вопрос 2: как лучше хранить в бд список 'Цвет' для пользователя? В виде строки или создать доп. таблицу, где хранить id пользователя и id пунктов которые он выбрал. Или другой вариант?
Вопрос 3: как получить результирующую выборку для листбокса.(Мысли, варианты, подсказки...). Я в тупике.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.09.2017, 22:32
Ответы с готовыми решениями:

Пользователи онлайн
Нужно простенький код который будет показывать сколько человек на сайте 56 Игроков online типо такого

Мини онлайн бот для накрутки онлайн-времени в игре
Я играю в игру сайтовую там раз в 2 часа можно получить монетки. У меня вопрос как сделать онлайн бот который бы заходил на...

Мини онлайн бот для накрутки онлайн-времени в игре
Не закрывайте тему))) Мне просто интересно как сделать онлайн бот не накрутчик))) Бот который соединялся с...

3
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
30.09.2017, 03:25
Pavel Rem, 1) Можно на каждом хите записывать в бд дату последней активности, потом делать выборку по промежутку этой даты.
2) Доп таблицу с id.
1
 Аватар для Pavel Rem
11 / 11 / 2
Регистрация: 15.07.2016
Сообщений: 132
30.09.2017, 16:00  [ТС]
Цитата Сообщение от sad67man Посмотреть сообщение
на каждом хите записывать в бд дату последней активности,
А можно по подробнее? Не могу сообразить. Нужно записывать в бд дату, при в ходе на сайт или при выходе?
Или вобще при каждом действии на сайте делать запись?
И как потом будет выглядеть запрос в бд? Выбрать всех пользователей у которых тип-1 и дата активности меньше текущей?
Или нужно записывать дату-время входа на сайт и дату-время выхода. И делать выборку тех у кого в этот диапазон попадает текущая дата?

Цитата Сообщение от sad67man Посмотреть сообщение
Доп таблицу с id.
Если пользователь выберет несколько вариантов, например 3, в этой таблице будет 3 записи:
User 25. Цвет 2.
User 25. Цвет 4.
User 25. Цвет 1.

И все остальные пользователи будут записываться в эту же таблицу?
Если в среднем будут выбирать 3 пункта, а пользователей, в теории, будет 1000, в таблице будет 3000 записей.
Я все правильно понял?
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
30.09.2017, 22:54
Лучший ответ Сообщение было отмечено Pavel Rem как решение

Решение

Цитата Сообщение от Pavel Rem Посмотреть сообщение
А можно по подробнее? Не могу сообразить. Нужно записывать в бд дату, при в ходе на сайт или при выходе?
Или вобще при каждом действии на сайте делать запись?
При каждом действии на сайте
Запрос для обновления даты активности (last_active_date - datetime) будет выглядеть примерно так
SQL
1
UPDATE `users` SET `last_active_date`= NOW() WHERE id = 2
Запрос пользователей онлайн
SQL
1
SELECT * FROM `users` WHERE last_active_date > DATE_SUB(NOW(), INTERVAL 10 MINUTE)
Добавлено через 1 минуту
Цитата Сообщение от Pavel Rem Посмотреть сообщение
Если в среднем будут выбирать 3 пункта, а пользователей, в теории, будет 1000, в таблице будет 3000 записей.
Я все правильно понял?
Все верно
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.09.2017, 22:54
Помогаю со студенческими работами здесь

Онлайн пользователи
Здравствуйте.Такая проблемка: переехал на VPS и перестало работать кто онлайн.Все файлы на месте,в чем проблемка то?

Пользователи онлайн
Здравствуйте! Подскажите, пожалуйста, плагин или как сделать отображение блока &quot;кто онлайн&quot;. Желательно чтобы результат...

Пользователи онлайн mvc
Чтобы вывести кто онлайн я планирую использовать отдельную таблицу , пользователь при любых действиях будет удалять из таблицы записи в...

Кто на сайте (пользователи онлайн)
Здравствуйте. Возникла идея отображать на сайте сколько сейчас людей он-лайн. (mySQL и PHP) Хочу поделиться написанным для...

Локальные пользователи отвалились из группы "пользователи"
Коротко о проблеме. Есть некоторое количество пользователей, все они находятся в группе &quot;пользователи&quot;. Не так давно (когда и...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru