Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: MySQL. Иерархические запросы.  (Прочитано 52644 раз)
0 Пользователей и 1 Гость смотрят эту тему.
RXL
Технический
Администратор

Offline Offline
Пол: Мужской

WWW
« : 05-11-2008 16:32 » 

Обсуждение статьи: «MySQL. Иерархические запросы.»
« Последнее редактирование: 26-08-2011 12:47 от RXL » Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
baldr
Команда клуба

cy
Offline Offline
Пол: Мужской
Дорогие россияне


WWW
« Ответ #1 : 01-08-2011 11:11 » 

Вот, понадобился обход дерева в MySQL базе и дошел я до этой статьи. RXL - спасибо, очень помогла вначале..
Но...
В таблице >91к записей.
В нужной мне ветке ровно 2000 листьев, которые я и хочу вытащить. Максимальная глубина вложенности (на глаз) не более 5-8. Однако, узлов довольно много (скажем, всего раз в 5 меньше чем листьев). В этом случае следующий statement в какой-то момент превышает масимальную длину для запроса:
Код: (MySQL)
        SET @stm = CONCAT(
            'SELECT GROUP_CONCAT(id) INTO @parents FROM test1',
            ' WHERE parent_id IN (', @parents, ')'
        );
Можно ли тут использовать рекурсию?
« Последнее редактирование: 01-08-2011 11:16 от baldr » Записан

Приличный компьютер всегда будет стоить дороже 1000 долларов, потому что 500 долларов - это не вполне прилично
RXL
Технический
Администратор

Offline Offline
Пол: Мужской

WWW
« Ответ #2 : 01-08-2011 13:59 » 

Длина строки, образуемой GROUP_CONCAT(), ограничена. Ограничение задано в переменной group_concat_max_len.

Цитата
The result is truncated to the maximum length that is given by the group_concat_max_len system variable, which has a
default value of 1024. The value can be set higher, although the effective maximum length of the return value is constrained by
the value of max_allowed_packet. The syntax to change the value of group_concat_max_len at runtime is as follows,
where val is an unsigned integer:

Код: (MySQL)
SET [SESSION | GLOBAL] group_concat_max_len = val;

Посмотри еще вторую статью - там немного переделанный вариант: https://forum.shelek.ru/index.php/topic,17151.0.html
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines