Вопрос с SQL

программирование веб дизайн базы данных

Есть сайт, там много вложенных папок, одна папка может содержать более 2000 вложенных.
Структура таблицы MYSQL примерно такая: FOLDERID, PARENTID , где FOLDER - Id Папки (порядковый номер), а PARENTID (это папка - родитель этой папки).
Как можно быстро сосчитать количество вложенных папок ? Потому что рекурсивное подсчитывание папок постепенно углубляясь занимает довольно большое время (имеется ввиду по одному запросу, используя PHP). Есть ли другие варианты?

Примечание:
Andrey.korea: MYSQL 5 не дружит с конструкцией WITH ... (
Ответы:
"MYSQL 5 не дружит с конструкцией WITH ... (" - тогда вам остается только посочувствовать.
заведите еще одно поле subfolderCount и посчитайте его один раз для всех записей через рекурсию или без. в дальнейшем обновляйте по мере изменения структуры. это будет проще и быстрее.
А еще наверное MySQL не дружит с тригерами.
Есть книга по древовидным структурам - может она поможет


14 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.