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]   

> Без описания
michael
Отправлено: 02 Ноября, 2007 - 11:27:20
Post Id


Новичок


Покинул форум
Сообщений всего: 23
Дата рег-ции: Нояб. 2007  


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




Имеется таблица, содержащая столбец Id, parentId, name. Как построить дерево?Помогите... подскажите... как лучше...
 
 Top
evgenijj
Отправлено: 02 Ноября, 2007 - 11:49:24
Post Id



Участник


Покинул форум
Сообщений всего: 1212
Дата рег-ции: Авг. 2006  
Откуда: Москва


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




PHP:
скопировать код в буфер обмена
  1.  
  2. // Получаем дерево категорий
  3. $categories = get_ctgs_tree( 0, 0 );
  4.        
  5. echo "<h3>Дерево каталога</h3>\\n";
  6. foreach ( $categories as $ctg )
  7. {
  8.     // выводим массив
  9.     // $ctg[0] - уникальный ID категории
  10.     // $ctg[1] - наименование категории
  11.     // $ctg[2] - описание
  12.     // $ctg[3] - уровень вложенности (чтобы делать отступы)
  13. }
  14.  
  15. // Функция возвращает дерево категорий в виде массива
  16. function get_ctgs_tree($parent, $level)
  17. {
  18.         $query = "SELECT id_ctg, name, description FROM ".TABLE_CATEGORIES." WHERE id_parent=".$parent." ORDER BY orders";
  19.         $res = mysql_query( $query ) or die (mysql_error());
  20.         $ctg = array(); // категории
  21.         while ($row = mysql_fetch_row($q))
  22.         {
  23.                 // Уровень вложенности категории
  24.                 $row[3] = $level;
  25.                 $ctg[] = $row;
  26.                 // получаем подкатегории для текущей категории
  27.                 $children = get_ctgs_tree($row[0], $level+1);
  28.                 // добавляем детей текущей категории в конец массива $ctg[]
  29.                 for ($j=0; $j<count($children); $j++)
  30.                 {
  31.                         $ctg[] = $children[$j];
  32.                 }
  33.         }
  34.         return $ctg;
  35. }
  36.  
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB