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]   

> Без описания
tamerlan212
Отправлено: 05 Апреля, 2024 - 18:02:35
Post Id


Новичок


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


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




Мне нужно строки из таблицы в многоуровневые массивы. Как это сделать, я не могу понять, и найти в поиске тоже, потому что не могу сформулировать правильный запрос.

У меня имеется таблица в базе данных с сотнями строк состоящие из нескольких полей
ID (ai) | NAME | PARENT

Представим это как категории. Если PARENT в строке NULL, значит это первый уровень. Уровней вложений может быть бесконечно. Если в PARENT имеется какое то значение, то оно относится по ID к одному из значений выше в этой таблице, это дочерний элемент.

По итогу мне нужно получить с вложенными дочерними элементами многоуровневый массив. Давайте покажу на примере

Например имеем:
ID | NAME | PARENT
--------------------
1 | тест 1 | NULL
2 | тест 2 | NULL
3 | тест 3 | 1
4 | тест 4 | 3

Сначала выгружаю весь список из бд, а дальше нужно распределить по массиву кто в кого вложен. Должен получиться такой массив

CODE (htmlphp):
скопировать код в буфер обмена
  1. (
  2.     [0] => Array
  3.         (
  4.             [ID] => 1
  5.             [NAME] => тест 1
  6.             [CHILDREN] => Array
  7.                 (
  8.                     [ID] => 3
  9.                     [NAME] => тест 3
  10.                     [CHILDREN] => Array
  11.                         (
  12.                             [ID] => 4
  13.                             [NAME] => тест 4
  14.                             [CHILDREN] =>
  15.                         )
  16.  
  17.                 )
  18.  
  19.         )
  20.  
  21.     [1] => Array
  22.         (
  23.             [ID] => 2
  24.             [NAME] => тест 2
  25.             [CHILDREN] =>
  26.         )
  27.  
  28. )
  29.  


Как это можно реализовать?

Возникали идеи с foreach, но в итоге заходил в тупик когда нужно как то в памяти хранить очередность вложений того или иного родителя
 
 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