Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2009.07.12;
Скачать: CL | DM;

Вниз

Sql запрос для таблица которая связана сама с собой   Найти похожие ветки 

 
Mishenka   (2009-05-18 16:31) [0]

Есть таблица с полями ID, ModuleName, ParentID. Таблица описывает древовидную структуру, где в поле ParentID содержится ID родительской записи из той же таблицы. Нужно написать запрос, который бы по заданному параметру ID выводил поле ModuleName и тоже поле ModuleName для родительской записи.

Пишу так:
SELECT M.ModuleName, M2.ModuleName as ParentModuleName
FROM Modules M, Modules M2
WHERE (M.ParentID = M2.ID) AND (M.ID = :IDModule)

где IDModule это заданный параметр. Для дочерних записей всё работает нормально. Однако для родительских, тобишь у которых ParentID не ссылается ни на какую запись, в результате выводится пустой набор, а нужно чтоб выводилась одна запись с пустым значением поля ParentModuleName. Как изменить запрос, чтоб всё работало нормально???


 
palva ©   (2009-05-18 16:39) [1]

Наверно, так:
SELECT M.ModuleName, M2.ModuleName as ParentModuleName
FROM Modules M
LEFT JOIN Modules M2 ON M.ParentID = M2.ID
WHERE M.ID = :IDModule


 
Ega23 ©   (2009-05-18 16:41) [2]

Select C.CatName, IsNull(C1.CatName, "") as ParCatName
from Mat$categories C left join Mat$categories C1 on (C.ParCatId=C1.CatID)


 
Mishenka   (2009-05-19 14:49) [3]

Всё заработало, спасибо!


 
Игорь Шевченко ©   (2009-05-19 14:53) [4]


> а нужно чтоб выводилась одна запись с пустым значением поля
> ParentModuleName. Как изменить запрос, чтоб всё работало
> нормально???


использовать OUTER JOIN ?



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

Текущий архив: 2009.07.12;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.009 c
2-1242802069
roadster
2009-05-20 10:47
2009.07.12
Зашитые в код строковые константы- как защитить их от просмотра?


2-1242895627
Roman88
2009-05-21 12:47
2009.07.12
Работа с Clob в Oracle


9-1181045233
MERLIN:)
2007-06-05 16:07
2009.07.12
Шрифты для игры


15-1242078495
ford
2009-05-12 01:48
2009.07.12
FastMM непонятно прав он или нет


6-1204586032
Квэнди
2008-03-04 02:13
2009.07.12
Indy 9 и ограничение скорости