Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вывод всего пути в древовидной структуре. 
:(
    Опции темы
stmamont
Дата 22.3.2006, 21:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 343
Регистрация: 13.3.2004
Где: влг

Репутация: нет
Всего: 3



У меня есть древовидная структура разделов.
Хочу составить запрос чтоб получить следующую информацию (порядок важен)

root_section some_content
section_level_1 some_content2
section_level_2 some_content3

Таблица сделана следующим образом
id
parent_id
content

Пишу в PostgreSQL.
Может быть сделать рекурсивную функцию в pgsql чтоб она добавляла в конец массива свеженайденный id.
Что то у меня никак не получается(


--------------------
user posted image
PM MAIL ICQ   Вверх
Vit
Дата 23.3.2006, 15:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



Или в цикле или рекурсией. С Postgre незнаком, но на MS SQL Server решал задачу циклом


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
chief39
Дата 24.3.2006, 13:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Цитата(Vit @ 23.3.2006, 15:21 Найти цитируемый пост)
Или в цикле или рекурсией. С Postgre незнаком

Он конкретный код спрашивает, я так понимаю... в том-то и проблема.. постгресовцы чот-то молчат :-/


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
stmamont
Дата 27.3.2006, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 343
Регистрация: 13.3.2004
Где: влг

Репутация: нет
Всего: 3



Я посмотрел, такие вещи только на pl/pgsql
или что то типа того можно сделать...
Добавлено @ 20:27
Вопрос. Как мне установить поддержку этого самого pl/sql?
Короче как мне сделать так чтоб им можно было работать?


--------------------
user posted image
PM MAIL ICQ   Вверх
batigoal
Дата 28.3.2006, 08:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 1
Всего: 151



Цитата(stmamont @ 27.3.2006, 21:24 Найти цитируемый пост)
Я посмотрел, такие вещи только на pl/pgsql
или что то типа того можно сделать...
Добавлено @ 21:27
Вопрос. Как мне установить поддержку этого самого pl/sql?
Короче как мне сделать так чтоб им можно было работать?

Там действительно есть средства для работы с иерархическими структурами, но установить ты его не сможешь - это язык СУБД Oracle.


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
stmamont
Дата 29.3.2006, 09:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 343
Регистрация: 13.3.2004
Где: влг

Репутация: нет
Всего: 3



а разве нету pl/pgsql специально для postgre? вроде в документации описано было или я ошибаюсь?


--------------------
user posted image
PM MAIL ICQ   Вверх
LSD
Дата 29.3.2006, 10:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



PL/PGSQL - есть, но ты просто написал PL/SQL, а вот его дейтвительно нет.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
tux
Дата 29.3.2006, 10:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: нет
Всего: 132



В Oracle язык называется pl/sql, в PostgreSQL - pl/pgsql, это разные вещи, хотя синтаксис похож. Обычно интерпретатор pl/pgsql в PostgreSQL уже включен. Если нет, то можно вручную его включить:
Код

CREATE FUNCTION plpgsql_call_handler() RETURNS language_handler AS
    '$libdir/plpgsql' LANGUAGE C;
CREATE TRUSTED PROCEDURAL LANGUAGE plpgsql
    HANDLER plpgsql_call_handler;

Работа с рекурсивными наборами в PostgreSQL - задача нетривиальная, но решаемая. Вот пример того, как это можно сделать - http://people.planetpostgresql.org/merlin/...th-PLPGSQL.html.
Вот еще статейка в самую точку - http://www.thescripts.com/forum/thread66221.html.

Это сообщение отредактировал(а) tux - 29.3.2006, 10:17
PM MAIL Skype GTalk Jabber YIM   Вверх
Vit
Дата 29.3.2006, 16:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



Цитата(tux @ 29.3.2006, 01:07 Найти цитируемый пост)
Работа с рекурсивными наборами в PostgreSQL - задача нетривиальная, но решаемая



А зачем там рекурсия? Обычного цикла не достаточно? Или циклы не поддерживаются? Рекурсией конечно тоже можно, но нагрузка гораздо больше и выполняться будет дольше. На T-SQL (MS SQL Server) это решается примерно так:
Код


Set @Level=0

Select @Level=ParentId From MyTable where ...
While @Id is not null
  begin
    Select @id=ParentId, @MyContent=... From MyTable where ...
    Set @Level=Level+1
    
   Insert into TempTable
   Values (@Level, @MyContent)
  end


Не верю чтоб в PL/PGSQL не было оператора While или Goto+if


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
stmamont
Дата 30.3.2006, 12:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 343
Регистрация: 13.3.2004
Где: влг

Репутация: нет
Всего: 3



Спасибо большое за статьи.
Сегодня вечером обязательно прочитаю.


--------------------
user posted image
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0873 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.