[ Поиск ] - [ Пользователи ] - [ Календарь ]
Полная Версия: Циклы в MySQL
Shuriken
Доброго времени суток!

Есть таблица с категориями, в таблице есть поле parent_id, в которой содержится id из этой же таблицы и указывает, у самой верхней категории в иерархии parent_id IS NULL.

Задача: Есть id категории, необходимо вывести всё дерево до parent_id IS NULL.

На PHP циклами это сделать просто, но тулить запрос к базе в цикл не совсем правильно. Есть ли циклы в MySQL или какой-нибудь другой способ реализовать подобное одним запросом?

Заранее благодарен.
kaww
Можно и на стороне БД http://stackoverflow.com/questions/1651341...-mysql#32775285 , но обрати внимание на комментарии.
А еще можно правильно хранить деревья в БД http://mikehillyer.com/articles/managing-h...-data-in-mysql/
Shuriken
Цитата (kaww @ 26.10.2016 - 09:40)
Можно и на стороне БД http://stackoverflow.com/questions/1651341...-mysql#32775285 , но обрати внимание на комментарии.
А еще можно правильно хранить деревья в БД http://mikehillyer.com/articles/managing-h...-data-in-mysql/

Спасибо за ссылки. У меня возник вопрос по Nested Set Model. Если добавить новую подкатегорию, то нумерация left и right станет не актуальна и надо будет проставлять заново? Я правильно понял?
Michael
Цитата (Shuriken @ 26.10.2016 - 12:45)
Цитата (kaww @ 26.10.2016 - 09:40)
Можно и на стороне БД http://stackoverflow.com/questions/1651341...-mysql#32775285 , но обрати внимание на комментарии.
А еще можно правильно хранить деревья в БД http://mikehillyer.com/articles/managing-h...-data-in-mysql/

Спасибо за ссылки. У меня возник вопрос по Nested Set Model. Если добавить новую подкатегорию, то нумерация left и right станет не актуальна и надо будет проставлять заново? Я правильно понял?

да, при изменениях в дереве, надо пересчитывать ключи.

_____________
There never was a struggle in the soul of a good man that was not hard
sergeiss
Цитата (Shuriken @ 26.10.2016 - 11:04)
Есть ли циклы в MySQL или какой-нибудь другой способ реализовать подобное одним запросом?

Это есть в Постгре.

_____________
* Хэлп по PHP
* Описалово по JavaScript
* Хэлп и СУБД для PostgreSQL

* Обучаю PHP, JS, вёрстке. Интерактивно и качественно. За разумные деньги.

* "накапливаю умение телепатии" (С) и "гуглю за ваш счет" (С)

user posted image
Michael
Есть методы и попроще Nested Sets:

https://habrahabr.ru/post/263629/

_____________
There never was a struggle in the soul of a good man that was not hard
Быстрый ответ:

 Графические смайлики |  Показывать подпись
Здесь расположена полная версия этой страницы.
Invision Power Board © 2001-2025 Invision Power Services, Inc.