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]   

> Без описания
des1roer
Отправлено: 24 Марта, 2015 - 12:34:57
Post Id



Новичок


Покинул форум
Сообщений всего: 33
Дата рег-ции: Апр. 2014  


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




Вроде тема изъезженная, но вот наткнуться на реализацию не могу.
есть таблица типовая
ид\имя\ид предка.
хочу добится такого
CODE (htmlphp):
скопировать код в буфер обмена
  1. (
  2.     1 => array
  3.     (
  4.         'text' => 'page/index'
  5.         'id' => 4
  6.         'expanded' => false
  7.         'children' => array
  8.         (
  9.             0 => array
  10.             (
  11.                 'text' => 'site/index'
  12.                 'id' => 5
  13.                 'expanded' => false
  14.             )
  15.         )
  16.     )
  17.     4 => array
  18.     (
  19.         'text' => '222'
  20.         'id' => 2
  21.         'expanded' => false
  22.         'children' => array
  23.         (
  24.             0 => array
  25.             (
  26.                 'text' => '3'
  27.                 'id' => 3
  28.                 'expanded' => false
  29.                 'children' => array
  30.                 (
  31.                     0 => array
  32.                     (
  33.                         'text' => '4'
  34.                         'id' => 7
  35.                         'expanded' => false
  36.                     )
  37.                 )
  38.             )
  39.             1 => array
  40.             (
  41.                 'text' => '22222'
  42.                 'id' => 8
  43.                 'expanded' => false
  44.             )
  45.         )
  46.     )

нужно рекурсивно пробежаться по всем полученным данным и в зависимости какой ид предка закинуть в тот массив. у корня ид предка соотвественно нулл
 
 Top
des1roer
Отправлено: 25 Марта, 2015 - 08:57:40
Post Id



Новичок


Покинул форум
Сообщений всего: 33
Дата рег-ции: Апр. 2014  


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




CODE (htmlphp):
скопировать код в буфер обмена
  1. $a = Page::model()->findAll();
  2. foreach ($a as $user)
  3. {
  4.         $all[$user->p_parent][] = array(id => $user->p_id, text=> $user->p_title, parent_id => $user->p_parent);  
  5. }
  6. function RecursiveTree2(&$rs, $parent)
  7. {
  8.    $out = array();
  9.     if (!isset($rs[$parent]))
  10.     {
  11.         return $out;
  12.     }
  13.     foreach ($rs[$parent] as $row)
  14.     {
  15.         $chidls = RecursiveTree2($rs, $row['id']);
  16.         if ($chidls)
  17.         {
  18.             $row['expanded'] = false;
  19.             $row['children'] = $chidls;            
  20.         }
  21.         $out[] = $row;
  22.     }
  23.     return $out;
  24. }
  25. $this->widget('CTreeView', array('data' => RecursiveTree2($all ,0), 'htmlOptions' => array('class' => 'treeview-red')));

дамп массива
CODE (htmlphp):
скопировать код в буфер обмена
  1. array(7) {
  2.   [2]=>
  3.   array(2) {
  4.     [0]=>
  5.     array(3) {
  6.       ["id"]=>
  7.       int(3)
  8.       ["text"]=>
  9.       string(1) "3"
  10.       ["parent_id"]=>
  11.       int(2)
  12.     }
  13.     [1]=>
  14.     array(3) {
  15.       ["id"]=>
  16.       int(8)
  17.       ["text"]=>
  18.       string(5) "22222"
  19.       ["parent_id"]=>
  20.       int(2)
  21.     }
  22.   }
 
 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