170 похожих чатов

Господа бекендеры, есть sequelize, есть таблица на postgresql с категориями

товаров, в ней есть поля id и parentId. структура древовидная - то есть parentId ссылается на id в этой же таблице. Есть таблица с товарами с полем catId - ссылкой на таблицу с категориями.
каким образом можно для категории с id = N выбрать все товары всех детей.
или такой вопрос лучше в sql группах искать?

15 ответов

2 просмотра

Селект products where cat_id in (select cat_id from categories where parent_id = n)

FroG- Автор вопроса

вложенность может быть уровня 5-6

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

FroG- Автор вопроса

угу, сейчас пробую рекурсию делать в постгре, хочу проверить как быстро это будет работать.

FroG- Автор вопроса

но в sequelize наверное засунуть это не смогу )

угу. Смотри, самый простой и быстрый варик тут будет добавить колонку three, в которой хранить всю цепочку родителей категории. из серии 1,4,8,99 потом делать выборку, по самым нижним, джойнить, и делать uniqu

FroG- Автор вопроса

как вариант читал что можно добавить таблицу со всеми перечислениями связей в таблице, но всё же попробую пока рекурсию :D

да, так можно тоже) п.с. если на уровне базы не выйдет, можно дерево обхобходить в коде и класть резалты в редись а вторым запросам собирать уже посты)

FroG- Автор вопроса

спасибо, пойду пробовать)

Я так понимаю категории не часто изменяются. Тогда nested sets то что вам нужно

FroG- Автор вопроса

загуглил и первую ссылку прочитал, если Вы про это, то я сломался https://habr.com/ru/post/63416/

в каком моменте сломались?

FroG- Автор вопроса

с ключами left right )

FroG- Автор вопроса

правда там в конце статьи про parentId скользом упомянуто...

все просто. у вас есть ид, парент ид, лево и право.

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
Здравствуйте. Задача состоит в том, чтобы сделать real-time чат в мобильном приложении. После передачи сообщения пользователем через веб-сокеты, для основного и долговременног...
🐾
5
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us 👉We offer Interview Support :-for a low cost variety of tech...
Rambabu Nallamilli
3
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
Книга Юрова В.И пойдёт для обучения?
Botsman
24
Hello experts, Could someone kindly tell me how to run vacuum inside a plpgsql function? If you have any link please share. Thank you
Amol Palav
10
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Приветствую, уважаемые граждане! Пытаюсь создать var A: array[1_000_000_000, float] При компиляции ошибка. Машина с 8 ГБ оперативной памяти. И я понимаю, что А будет занимат...
|
5
Карта сайта