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]   

> Без описания
etoYA
Отправлено: 09 Ноября, 2013 - 13:49:07
Post Id



Участник


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


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




Есть такая таблица

CODE (htmlphp):
скопировать код в буфер обмена
  1. id | name        | parent_id
  2. ------------------------------------
  3. 1   Кондиционеры    0
  4. 2   Daikin          1
  5. 3   Panasonic       1
  6. 4   Mitsubishi      1
  7. 5   Hyundai         1
  8. ------------------------------------


Можно ли составить такой SQL запрос, чтоб на выходе получить что-то такое
PHP:
скопировать код в буфер обмена
  1.  
  2.         0 => array(
  3.                 'id' => 1
  4.                 'name' => 'Кондиционеры'
  5.                 'childs' => array(
  6.                         'id' => 2
  7.                         'name' => 'Daikin',
  8.                         'id' => 3
  9.                         'name' => 'Panasonic',
  10.                         'id' => 4
  11.                         'name' => 'Mitsubishi',
  12.                         'id' => 5
  13.                         'name' => 'Hyundai',
  14.                 )
  15.         )
  16. )
  17.  


Или придется просто выбрать все, а там уже самому делать такой массив?

(Отредактировано автором: 09 Ноября, 2013 - 13:50:21)

 
 Top
EuGen Администратор
Отправлено: 09 Ноября, 2013 - 15:18:06
Post Id


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


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


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




Зависит от того, сколько уровней вложенности существует. Если фиксированное число - то можно одним запросом. Либо же - изменить структуру таблицы (см. nested sets)


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
etoYA
Отправлено: 09 Ноября, 2013 - 15:33:30
Post Id



Участник


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


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




EuGen, уровней всего 2.

Т.е категория и саб категория

(Отредактировано автором: 09 Ноября, 2013 - 15:33:47)

 
 Top
EuGen Администратор
Отправлено: 09 Ноября, 2013 - 15:59:13
Post Id


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


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


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




Тогда запрос будет таким:

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT
  2.   parent.id AS parent_id,
  3.   parent.name AS parent_name,
  4.   child.id AS child_id,
  5.   child.name AS child_name
  6. FROM
  7.   t AS parent
  8.     LEFT JOIN t AS child
  9.       ON parent.id=child.parent_id

- а в коде сбор данных нужно делать:
PHP:
скопировать код в буфер обмена
  1. //$select derived from DB driver
  2. $result = [];
  3. while($row=mysqli_fetch_array($select))
  4. {
  5.    $result[$row['parent_id']] = [
  6.       'id'   => $row['parent_id'],
  7.       'name' => $row['parent_name']
  8.    ];
  9.    $result[$row['parent_id']]['childs'][] = [
  10.       'id'   => $row['child_id'],
  11.       'name' => $row['child_name']
  12.    ];
  13. }


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
etoYA
Отправлено: 09 Ноября, 2013 - 16:53:54
Post Id



Участник


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


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




Спасиб
 
 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