Похожие чаты

Всем привет) Есть интересный вопрос и у меня он вызвал

затруднения. Приведу пример двух таблиц в упрощённом виде:
```
Table A:
id: str
parent_id: Optional[str]
level: int
parent = relationship('A')
children Mapped[list['A'] = relationship('A')


Table B:
id: str
a_id: ForeignKey('a.id')

Таблица B относится к А как M:1

Суть в чём. Необходимо вывести от передаваемого уровня(к примеру идёт вложенность 1-ого до 15-ого уровня и пусть я передаю 1-ый уровень) всех children. Это не проблема. Но мне нужно посчитать для первого уровня общее количество func.count(b.id). То есть логично, что для 1-ого уровня это будут все, которые относятся от 1 до 15 уровня. 2-ых уровней таблицы А может быть несколько. И нужно, отдельно для каждого посчитать от 2 уровня до 15. И хотелось бы всё это вернуть одним запросом. Господа, как?)))

5 ответов

25 просмотров

Рекурсивным cte

Можно сначала развернуть дерево полностью добавив к каждой итерации разворачивания столбец с числом, соответствующим уровню вложенности, потом джойнить B, а потом только считать count

Igor'-Pypkin 🫥 Автор вопроса
Artemiy
Можно сначала развернуть дерево полностью добавив ...

давай всё же на ты) Вся проблема в том, что к каждому уровня А, относится определённое количество Б записей. И если считать всё рекурсивно, нужно будет грузить это всё в память. С вариантом cte это можно избежать, а вот как избежать это с sql запросом(хотя знаю, что должен быть способ это всё посчитать одним запросом:)), я хз)

Igor'-Pypkin 🫥 Автор вопроса
Artemiy
Так CTE это же всё равно часть SQL-запроса

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
@Benzenoid can you tell me the easiest, and safest way to bu.y HEX now?
Živa Žena
20
This is a question from my wife who make a fortune with memes 😂😂 About the Migration and Tokens: 1. How will the old tokens be migrated to the new $LGCYX network? What is th...
🍿 °anton°
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
What is the Dex situation? Agora team started with the Pnetwork for their dex which helped them both with integration. It’s completed but as you can see from the Pnetwork ann...
Ben
1
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Anyone knows where there are some instructions or discort about failed bridge transactions ?
Jochem
21
@lozuk how do I get my phex copies of my ehex from a atomic wallet, to move to my rabby?
Justfrontin 👀
11
Карта сайта