Рекурсивные SQL-запросыРекурсивные SQL-запросы являются одним из способов решения проблемы дерева и других проблем, требующих рекурсивную обработку. Они были добавлены в стандарт SQL 99. До этого они уже существовали в Oracle. Несмотря на то, что стандарт вышел так давно, реализации запоздали. Например, в MS SQL они появились только в 2005-ом сервере. with [recursive] <имя_алиаса_запроса> [ (<список столбцов>) ] В MS SQL нет ключевого слова recursive, а в остальном все тоже самое. Такой синтаксис поддерживается в DB2, Sybase iAnywhere, MS SQL и во всех базах данных, которые поддерживают стандарт SQL 99. Проще разобрать на примере. Предположим, есть таблица: create table tree_sample (
id - идентификатор Для вывода дерева: with recursive tree (nm, id, level, pathstr)
Этот пример выведет дерево по таблице с отступами. Первый запрос из tree_sample этот запрос выдаст все корни дерева. Второй запрос соединяет между собой таблицу tree_sample и tree, которая определяется этим же запросом. Этот запрос дополняет таблицу узлами дерева. Сначала выполняется первый запрос. Потом к его результатам добавляются результаты второго запроса, где данные таблица tree - это результат первого запроса. Затем снова выполняется второй запрос, но данные таблицы tree - это уже результат предыдущего выполнения второго запроса. И так далее. На самом деле база данных работает не совсем так, но результат будет таким же, как результат работы описанного алгоритма. После этого данные этой таблицы можно использовать в основном запросе как обычно. Хочу заметить, что я не говорю о применимости конкретно этого примера, а лишь пишу его для демонстрации возможностей рекурсивных запросов. Этот запрос реально будет работать достаточно медленно из-за order by. |