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]   

> Без описания
BIOHAZARD
Отправлено: 08 Октября, 2011 - 17:02:58
Post Id


Новичок


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


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




в SQL полный профан, так что прошу помощи от коллективного разума

таблица members имеет примерную структуру
id_member | referred_by | points

данные:
1 | 0 | 99
2 | 1 | 11

в качестве исходных данных имеется id_member=2 и надо добавить один points пользователю с id_member = (referred_by пользователя с id_member=2)

т.е. на входе id_member=2? на выходе надо увеличить 99 на единицу

вот как-то так
не могу даже придумать, что спросить по этому поводу у гугля
 
 Top
Мелкий Супермодератор
Отправлено: 08 Октября, 2011 - 17:08:05
Post Id



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


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


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




CODE (SQL):
скопировать код в буфер обмена
  1. UPDATE `members` SET `points`=`points`+1 WHERE `reffered_by`=2

(Добавление)
или наоборот?
Опишите словами, что здесь происходит. Т.е. для чего это всё.


-----
PostgreSQL DBA
 
 Top
White
Отправлено: 08 Октября, 2011 - 17:15:56
Post Id



Частый посетитель


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


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




CODE (SQL):
скопировать код в буфер обмена
  1. UPDATE `members` SET `points`=`points`+1 WHERE `id` IN (2,(SELECT `reffered_by` FROM `members` WHERE `id`=2))


-----
if(time()>1356048000) die();
 
 Top
BIOHAZARD
Отправлено: 08 Октября, 2011 - 17:27:17
Post Id


Новичок


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


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




Мелкий пишет:
Опишите словами, что здесь происходит. Т.е. для чего это всё.
есть система рефералов

при публикации сообщения пользователем с id_member = 2 надо накинуть один пойнт его рефереру, id реферера хранится в поле reffered_by

White, а так можно:
CODE (SQL):
скопировать код в буфер обмена
  1. UPDATE `members` SET `points`=`points`+1 WHERE `id`  = (SELECT `reffered_by` FROM `members` WHERE `id`= 2 LIMIT 1) LIMIT 1;

??
 
 Top
White
Отправлено: 08 Октября, 2011 - 18:01:52
Post Id



Частый посетитель


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


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




BIOHAZARD да, так можно.


-----
if(time()>1356048000) die();
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB