Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2009.12.06;
Скачать: [xml.tar.bz2];

Вниз

рекурсия, CTE и сортировка как в оракле   Найти похожие ветки 

 
Медвежонок Пятачок ©   (2008-12-31 13:07) [0]

Имеем запрос, использующий cte: /*mssql2005*/
with testtest(id, pid, level) as
(
select id, pid, 0 as level
from test
where pid is null
  union all
select e.id, e.pid, level + 1
from test e
join testtest d on e.pid = d.id
)
select * from testtest

Можно ли наточить запрос (тот что выше) так, чтобы он сортировал записи древовидного запроса аналогично оракловому :

select t.*,level from test t
connect by prior id=pid start with pid is null

то есть требуется чтобы было :
первый рутовый элемент, все его дети и дети их детей, затем следующий рутовый элемент и т.д


 
Медвежонок Пятачок ©   (2008-12-31 13:52) [1]

пока удалось забацать это через производные строковые поля
но может есть способ понативнее?

WITH menu_tree(id, pid, caption, mlevel) AS
(
SELECT ID, PID, caption, cast("0" + cast(id as varchar(10)) as varchar(10)) AS mlevel
FROM menu
WHERE PID IS NULL
  UNION ALL
SELECT e.ID, e.PID, e.caption, cast(mlevel + cast(e.id as varchar(10)) as varchar(10)) as mlevel
FROM menu e
JOIN menu_tree d
ON e.pid = d.id
)
SELECT *
FROM menu_tree order by mlevel


 
Johnmen ©   (2009-01-03 01:58) [2]

Это что? Типа давайте наморщим лоб? Срочное письмо Билу?
Ты бы БД попроще делал, и нормализацию соблюдал. Глядишь, и вопросов бы нЕ было...


 
Поросенок Винни-Пух ©   (2009-01-03 14:04) [3]

скажи проще: ты в этом ни бум-бум и тебе лично такое никогда в голову не приходило.

нормализацию еще приплел. пипец....


 
Поросенок Винни-Пух ©   (2009-01-03 14:10) [4]

Ты бы БД попроще делал

нафик залезать в ветку, если для тебя табличка

id,pid,caption

выглядит сложной?


 
ANB   (2009-01-05 17:05) [5]


> Медвежонок Пятачок ©   (31.12.08 13:52) [1]

В оракле order by по connect by тоже нетривиальная задачка. До 10-ки никак не работала. Без сортировки выдавалось все по уровням, но даже отсортировать по алфавиту внутри ветки не получалось.
Помогало создание индекса типа PID, CAPTION, но не гарантировалось, что всегда будет работать.

Вывод - работает хоть так и будь счастлив :)



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2009.12.06;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.004 c
15-1255180534
Artem
2009-10-10 17:15
2009.12.06
Проблема


8-1190053070
Дельфин
2007-09-17 22:17
2009.12.06
Несколько потоков звука в программе


2-1255533352
madmech
2009-10-14 19:15
2009.12.06
Как отстроить ширину и высоту у DBGrid


2-1255841231
NaRuTo
2009-10-18 08:47
2009.12.06
Фокус 2-х и более TCustomControl ов


15-1254831159
Kolan
2009-10-06 16:12
2009.12.06
Как тестировать не публичные методы?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский