Кажется, что steam добавляет новую функцию eagerLoad
и удаляет alsoDecode
. Это удобно тем, у кого есть отношения между родителями и детьми или братьями и сестрами. Но не для тех, у кого нет отношений.
Я хочу реализовать древовидную структуру, узлы которой не могут быть (или я не знаю, как) участвовать в отношениях. У узлов есть родитель и множество дочерних узлов, которые тоже являются узлами.
Итак, у меня есть три таблицы для этой структуры.
Tree:
| Field | Type |
| ----------- | --------------- |
| id | UUID? |
| name | String |
| nodes | [Node] |
| paths | [Path] |
Nodes:
| Field | Type |
| ------------- | -------------------------- |
| id | UUID? |
| type | NodeType(root, leaf, node) |
| tree | Tree |
Path:
| Field | Type |
| ------------ | --------- |
| id | UUID? |
| distance | Int |
| ancestorID | UUID |
| descendantID | UUID |
| tree | Tree |
Вопрос в том, хочу ли я сделать
SELECT Nodes.id, Nodes.type, Path.ancestorID from Nodes
INNER JOIN Path
ON Nodes.id = Path.descendantID
Как писать коды.