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]   

> Без описания
ermax
Отправлено: 31 Мая, 2008 - 23:07:13
Post Id


Новичок


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


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




Допустим передается параметр id_parent со значением 11, выбираем все записи с таблице shop_groups
где значение id_parent равно 11.

CODE (text):
скопировать код в буфер обмена
  1. $id_img = $_GET["id_parent"];
  2.  
  3. $result = mysql_query("select * from shop_groups WHERE id_parent = ".$id_img."");
  4. $row = mysql_fetch_array($result, MYSQL_ASSOC);
  5.  
  6.  
  7. do {
  8. echo "Группа товара -".$row["name"];
  9. }
  10.  
  11. while ($row = mysql_fetch_array($result, MYSQL_ASSOC));


Здесь получается мы вывели все записи где id_parent равно 11.
Но мне нужен сложный массив.

Т.е. допустим мы нашли первую запись где id_parent равно 11 получили ее название + id
Теперь в другой таблице shop находим записи где id_parent равен текущей id выборки, т.е.

CODE (text):
скопировать код в буфер обмена
  1. $result = mysql_query("select * from shop WHERE id_parent = ".$row["id"]."");
  2. все тоже суем цикл
  3. do {
  4. echo "Товар -".$row["name"];
  5. }
  6.  
  7. while ($row = mysql_fetch_array($result, MYSQL_ASSOC));


суть в то что мне нужно получить вывод ввиде

Группа товара - бла бла
Товар - бла бла
Товар - бла бла
Товар - бла бла
Группа товара - бла бла
Товар - бла бла
Товар - бла бла
Товар - бла бла

Вот с этим и трудности... как вставить один массив в другой и получить такой результат вывода...
 
 Top
EuGen Администратор
Отправлено: 31 Мая, 2008 - 23:17:34
Post Id


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


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


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




PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3. $id_img = $_GET["id_parent"];
  4. $resExt=mysql_query("SELECT * FROM shop_groups WHERE id_parent = ".(int)($id_img));
  5. $rgResult=array();
  6. while($rowExt=mysql_fetch_array($resExt))
  7. {
  8.    $resInt=mysql_query("SELECT * FROM shop WHERE id_parent = ".(int)$rowExt["id"]);
  9.    while($rowInt=mysql_fetch_array($resInt))
  10.    {
  11.        $rgResult[$rowExt['name']][]=$rowInt['name'];
  12.    }
  13. }
  14. //на выходе у Вас есть $rgResult - то, что нужно.
  15. ?>
  16.  

Несколько замечаний по Вашему коду: не логично использовать цикл с постусловием при обработке выборки из БД - он выполняется всегда хотя бы 1 раз, тогда как в выборке может не быть ни одной строки.
Кроме того, нужно предусматривать некорректный ввод пользователя во избежание SQL-Injection.

(Отредактировано автором: 31 Мая, 2008 - 23:19:41)



-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 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