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
Форумы портала PHP.SU :: Версия для печати :: Многомерные массивы / нид хелп
Форумы портала PHP.SU » PHP » Напишите за меня, пожалуйста » Многомерные массивы / нид хелп

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

1. ermax - 31 Мая, 2008 - 23:07:13 - перейти к сообщению
Допустим передается параметр 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));


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

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

Вот с этим и трудности... как вставить один массив в другой и получить такой результат вывода...
2. EuGen - 31 Мая, 2008 - 23:17:34 - перейти к сообщению
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.

 

Powered by ExBB FM 1.0 RC1