Хобрук: Ваш путь к мастерству в программировании

Как рекурсивно получить записи в Laravel?

У меня есть сущность, называемая сообщениями в моем приложении. Сообщения могут быть дочерними по отношению к другим сообщениям, поэтому родительское сообщение имеет hasMany('posts'), а дочернее имеет hasOne('post'), включение бесконечно.

Вот схема:

введите описание изображения здесь

Как я могу рекурсивно получить всех дочерних элементов и дочерних элементов и т. д. первого сообщения, для которого значение «post_id» равно нулю?

Пожалуйста, не комментируйте здесь производительность, я знаю, что такая схема плоха, я хочу знать только, как правильно написать рекурсивную функцию для извлечения бесконечных вложенных сообщений.

Например, допустим, у меня есть первое сообщение 1.
Сообщение 2 и 3 являются дочерними элементами сообщения 1.
Сообщение 4 и 5 являются дочерними элементами сообщения 2.
Сообщение 6 и 7 являются дочерними элементами сообщения 3.
Посты 8, 9, 10 являются дочерними элементами поста 5.
Посты 11, 12, 13 являются дочерними элементами поста 7.
Пост 14 являются дочерними элементами поста 10.
Я хочу написать рекурсивная функция, которая доставит мне посты 2-14. введите описание изображения здесь

11.10.2016

  • Эта логическая конструкция кажется не очень продуманной. Могу я спросить, почему такое глубокое встраивание постов? На Facebook они глубоко встраивают до 2 в родительскую публикацию (Родитель -> комментарий -> комментарий к комментарию). 11.10.2016
  • Это неправильно, вы должны использовать hasMany в этом случае, поскольку в сообщении 1 есть 2 ребенка. 11.10.2016
  • @ Дерек, пожалуйста, забудь о том, почему это так, и о производительности. Это не тот случай. Наиболее важным для меня является написание рекурсивной функции. Что касается схемы, это не реальный вариант использования. 11.10.2016
  • Для чего-то действительно эффективного у вас, вероятно, должно быть 2 поля в вашей БД, parent_post и sub_parent_post - первое будет идентификатором сообщения верхнего уровня, которому оно принадлежит, а второе будет его непосредственным родителем сообщения. 11.10.2016
  • Затем просто запросите все сообщения с помощью parent_post, а затем обработайте sub_parent_post либо в своем PHP, либо в javascript. 11.10.2016
  • @ Дерек, я это уже знаю. Я уже один раз спрашивал в посте и еще раз спрашивал в комментарии - не спрашивайте про схему и производительность. Мой вопрос довольно ясен. 11.10.2016
  • Покажите, что вы пробовали и почему это не работает. Stackoverflow не является сервисом для написания кода. 11.10.2016
  • @Kyslik Модель Post имеет как hasMany, так и hasOne. hasOne для извлечения родителя и hasMany для извлечения дочерних элементов, и оба метода работают. 11.10.2016
  • Я сомневаюсь, что кто-нибудь ответит на этот вопрос, учитывая последствия для безопасности и эффективности. Stack Overflow — не место, где процветают плохие практики. 11.10.2016

Ответы:


1

Поскольку вы специально просили нас не комментировать производительность, вы должны просто добавить атрибут with в модель публикации, чтобы включить все дочерние элементы.

class Post extends Model
{

   protected $with = [
        'posts'
   ];

   public function posts() {
        return $this->hasMany(Post::class);
    }

}
11.10.2016
  • Большое спасибо, это то, что я искал. 11.10.2016
  • Новые материалы

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

    Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
    LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

    Структуры данных в C ++ - Часть 1
    Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

    Как я опубликовал свое первое приложение в App Store в 13 лет
    Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..