|
Как избежать циклов в рекурсивных запросах
|
|||
---|---|---|---|
#18+
Всем привет. Вопрос по CTE - рекурсивным. Если в БД присутствуют записи, приводящие к бесконечному циклу, как их избежать? В Oracle есть оператор nocycle (может, и костыль некий, но работает прекрасно), в Postgres есть что-то подобное? В интернетах предлагают ограничиться уровнем вложенности типа deph < 10, но это не интересно. Есть что-то более правильное, когда мы охватим все записи, но при этом, если встретим повторную запись, то не пойдем в цикл повторно? По сути, аналог nocycle в Oracle. Заранее спасибо. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.02.2021, 13:15 |
|
Как избежать циклов в рекурсивных запросах
|
|||
---|---|---|---|
#18+
Alexey Agafonov Всем привет. Вопрос по CTE - рекурсивным. Если в БД присутствуют записи, приводящие к бесконечному циклу, как их избежать? В Oracle есть оператор nocycle (может, и костыль некий, но работает прекрасно), в Postgres есть что-то подобное? В интернетах предлагают ограничиться уровнем вложенности типа deph < 10, но это не интересно. Есть что-то более правильное, когда мы охватим все записи, но при этом, если встретим повторную запись, то не пойдем в цикл повторно? По сути, аналог nocycle в Oracle. Заранее спасибо. Нет такого нет. Можно скостылить в виде массива накопителя уже увиденных данных если очень надо (но если у вас там десятки тысяч записей будут и больше обрабатываться это запретительно по памяти и скорости будет). -- Maxim Boguk лучшая поддержка PostgreSQL: dataegret.ru ... |
|||
:
Нравится:
Не нравится:
|
|||
20.02.2021, 13:31 |
|
Как избежать циклов в рекурсивных запросах
|
|||
---|---|---|---|
#18+
... |
|||
:
Нравится:
Не нравится:
|
|||
20.02.2021, 15:28 |
|
Как избежать циклов в рекурсивных запросах
|
|||
---|---|---|---|
#18+
Alexey Agafonov, Можно самому считать глубину рекурсии в запросе и ограничиваться по ней Код: plsql 1. 2. 3. 4. 5. 6.
Альтернативное решение, как сказали выше, накопление в массиве хешей уже обработанных строк. Но это сильно медленней. ... |
|||
:
Нравится:
Не нравится:
|
|||
21.02.2021, 11:58 |
|
|
start [/forum/topic.php?fid=53&tid=1994184]: |
0ms |
get settings: |
10ms |
get forum list: |
13ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
46ms |
get topic data: |
11ms |
get forum data: |
2ms |
get page messages: |
44ms |
get tp. blocked users: |
2ms |
others: | 283ms |
total: | 419ms |
0 / 0 |