Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Проверить кого не было

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Uchenik
Отправлено: 19 Августа, 2011 - 08:59:28
Post Id



Частый гость


Покинул форум
Сообщений всего: 187
Дата рег-ции: Авг. 2011  


Помог: 1 раз(а)




У меня в проекте после авторизации каждый вошедший пользователь оставляет "цифровой след" в специальной таблице базы данных "Stat"
Каждый админ имеет определённую группу пользователей, которых он наблюдает.
Как сделать чтобы вошедшему админу показывалось кто из его подопечных ещё не входил?
Я начал делать так
Запросил список всех пользователей вошедшего админа из таблицы Users, а дальше не могу сообразить как сравнить этот результат со списком всех пользователей, которые есть в таблице stat и выдать админу тех, кого нету в stat?
 
 Top
EuGen Администратор
Отправлено: 19 Августа, 2011 - 09:09:14
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




SELECT * FROM users_table LEFT JOIN stats_table ON users_table.id=stats_table.user_ id WHERE stats_table.user_id IS NULL

?


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Viper
Отправлено: 19 Августа, 2011 - 09:13:22
Post Id



Активный участник


Покинул форум
Сообщений всего: 4555
Дата рег-ции: Февр. 2007  
Откуда: Симферополь


Помог: 98 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT users FROM stats WHERE admin = $admin_id AND (last_active > некая_дата OR last_active IS NULL)

Выбираем юзеров из таблицы по определенному админу или дата последнего посещения больше определенного интервала времени.

Примерно так, т.к. вы не привели никакой информации о таблице и виде данных.

(Отредактировано автором: 19 Августа, 2011 - 09:16:44)



-----
Список фильмов с описанием, блекджеком и... для Joomla? -> https://киноархив[dot]com
Демо нового движка для сайта php.su -> php[dot]su, проект на гитхабе
 
 Top
Мелкий Супермодератор
Отправлено: 19 Августа, 2011 - 09:13:54
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `users` LEFT JOIN `stat` ON (ваш критерий объединения) WHERE `stat`.`какое-то_поле` IS NULL

или
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `users` WHERE NOT EXISTS (SELECT * FROM `stat` WHERE критерий_объединения)


Первый вариант скорей всего будет быстрее.


-----
PostgreSQL DBA
 
 Top
Uchenik
Отправлено: 19 Августа, 2011 - 10:40:47
Post Id



Частый гость


Покинул форум
Сообщений всего: 187
Дата рег-ции: Авг. 2011  


Помог: 1 раз(а)




Я попробую рассмотреть все предложенные варианты, спасибо
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB