1 / 1 / 0
Регистрация: 10.08.2014
Сообщений: 97

Как организовать хранение и вывод элементов таблицы с иерархией?

01.03.2021, 23:34. Показов 3717. Ответов 24

Студворк — интернет-сервис помощи студентам
Делаю интернет магазин на java Spring.
Как организовать в базе данных хранение элементов справочника с иерархией, чтоб можно было потом вывести данные примерно, как на фото ниже?
Планируется 3 уровня вложенности.
Миниатюры
Как организовать хранение и вывод элементов таблицы с иерархией?  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.03.2021, 23:34
Ответы с готовыми решениями:

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

Как организовать вывод данных из таблицы?
Есть таблица привязанная с access, как сделать вывод информации, что бы выводил список всей информации только мальчиков или только девочек....

Организовать ввод, хранение в массиве, вывод на экран следующих данных
Организовать ввод, хранение в массиве, вывод на экран следующих данных: Информация о движении поездов включающая номер поезда, пункт...

24
1 / 1 / 0
Регистрация: 10.08.2014
Сообщений: 97
16.03.2021, 14:15  [ТС]
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от xoraxax Посмотреть сообщение
ну ты хранишь в бд подкатегории, достаешь их оттуда, складываешь в java-классы. Как ты этим будешь пользоваться, я полагаю, тебе должно быть виднее?
Подскажите пож-та как в БД хранить подкатегории, class называется Category и получается, что он в себе должен хранить List<Category> т.е. список себя же, как это правильно организовать в базе, какие таблицы и связи делать?


Java
1
2
3
4
5
6
7
8
public class Category {
    private List<Category> children;
    private Integer id;
    private Integer parentId;
    private String categoryName;
 
    // гетеры сеттеры и т.п.
}
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
16.03.2021, 14:33
Все вместе хранится. Иерархия задана с помощью parentId
0
1 / 1 / 0
Регистрация: 10.08.2014
Сообщений: 97
16.03.2021, 15:21  [ТС]
Цитата Сообщение от xoraxax Посмотреть сообщение
Все вместе хранится. Иерархия задана с помощью parentId
Не понимаю, объясните как для совсем чайника

Поле "private List<Category> children;" в базе данных должно где-то быть или нет?
Или оно должно просто в памяти заполняться на основании поля "parentId"?
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
16.03.2021, 15:33
1) нет 2) да
0
1 / 1 / 0
Регистрация: 10.08.2014
Сообщений: 97
16.03.2021, 15:57  [ТС]
Цитата Сообщение от xoraxax Посмотреть сообщение
1) нет 2) да
Спасибо!


И наверное последний вопрос по данной теме.
После того как я заполнил всё дерево, как мне его вывести?
Как я понимаю нужно отобрать категории первого уровня (те у который "parentId" = null)
И потом по ним пройтись рекурсией чтоб вывести всех "children" и всех "children" у "children"?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.03.2021, 15:57
Помогаю со студенческими работами здесь

Организовать ввод, хранение в массиве, вывод на экран данных о студентах
Организовать ввод, хранение в массиве, вывод на экран данных о студентах: фамилия. имя, отчество, дата рождения(число, месяц, год),...

Организовать ввод, хранение в массиве, вывод на экран данных о студентах группы
Организовать ввод, хранение в массиве, вывод на экран данных о студентах группы: фамилия, имя, дата рождения , знак Зодиака. Вывести на...

Организовать ввод, хранение в массиве, вывод на экран данных о студентах группы
В задаче организовать ввод и вывод через процедуру. Организовать ввод с клавиатуры только одного элемента массива. Остальные элементы в...

Организовать ввод, хранение в массиве, вывод на экран данных о клиентах пункта проката ДВД-дисков
Организовать ввод, хранение в массиве, вывод на экран данных о клиентах пункта проката ДВД-дисков: фамилия, имя, отчество, адрес (улица,...

Организовать ввод, хранение в массиве, вывод на экран данных об учениках нескольких школ: фамилия, имя, отчество, адрес
Организовать ввод, хранение в массиве, вывод на экран данных об учениках нескольких школ: фамилия, имя, отчество, адрес (улица, дом,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
25
Ответ Создать тему
Опции темы

Новые блоги и статьи
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru