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]   

> Без описания
Elegant
Отправлено: 17 Сентября, 2014 - 18:30:10
Post Id



Частый гость


Покинул форум
Сообщений всего: 151
Дата рег-ции: Май 2012  


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




Добрый день! Есть проблема...Нужно сделать выборку из 2 таблиц БД
1. user - инфа о юзере
3. services - сервисы

в таблице USER есть колонка categ,а в ней значения (1, 2)
в таблице SERVICES есть две колонки ID и NAZVANIE
(1|Рука
2|Нога
3|Голова)

Вот что написал
PHP:
скопировать код в буфер обмена
  1.  
  2. $client=$_GET["client"];             -   берем нужный ID
  3. mysql_query("SET NAMES 'utf8'");
  4. $sql = "select user.id,user.categ,services .id as idid,
  5. services .nazvanie
  6. FROM user,services
  7. WHERE user.id=$client";
  8. $result = mysql_query($sql);
  9. while ($itog = mysql_fetch_array($result, MYSQL_ASSOC))
  10. {
  11. $categ=$itog["categ"];
  12. $pieces = explode(", ", $categ);   - перегоняем в массив....
  13. }
  14.  

А вот дальше я не знаю....
Нужно что бы на странице повилось типа такого
"CLIENT ID - 1(Рука, Нога)"

(Отредактировано автором: 17 Сентября, 2014 - 18:32:46)

 
 Top
tato
Отправлено: 18 Сентября, 2014 - 01:40:19
Post Id



Посетитель


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


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




Если Я вас правильно понял и в categ строка с перечислением, то это плохое решение. Вам нужна связь многие-ко-многим, т.е. еще одна табличка.

В данной ситуации нечего воротить и лучше уже в коде разбираться. Т.е. грузить пользователя и сервис отдельно.


-----
просто ?: сложно
 
 Top
RickMan
Отправлено: 18 Сентября, 2014 - 09:11:18
Post Id


Участник


Покинул форум
Сообщений всего: 1033
Дата рег-ции: Май 2012  


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




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT u.id, u.categ, s.id AS idid, s.nazvani FROM user u LEFT JOIN services s ON u.categ = s.id WHERE u.id=$client;
- попробвуй такой запрос
 
 Top
tato
Отправлено: 22 Сентября, 2014 - 09:03:17
Post Id



Посетитель


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


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




RickMan пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT u.id, u.categ, s.id AS idid, s.nazvani FROM user u LEFT JOIN services s ON u.categ = s.id WHERE u.id=$client;


И что это даст?


-----
просто ?: сложно
 
 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