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

Вниз

Как написать запрос к таблице (   Найти похожие ветки 

 
oleon   (2002-12-23 18:48) [0]

Как написать запрос чтобы он возвращал ID-шники всех детей?
ну т.е. ID шники записей, которые входят в эту ветку?


 
oleon   (2002-12-23 18:49) [1]

таблица ID, GROUPID, NAME


 
Delirium ©   (2002-12-23 19:11) [2]

CREATE procedure ap_UnrollingTreeKeys (
@StartNode varchar(50),
@idNode sysname,
@idParent sysname,
@TableName sysname )
as
exec("
set nocount on
select "+@idNode+" into #tmp
from "+@TableName+" where "+@idNode+"="+@StartNode+"
while exists(select "+@idNode+" from "+@TableName+"
where ("+@idParent+" in (select "+@idNode+" from #tmp))
and ("+@idNode+" not in (select "+@idNode+" from #tmp)))
insert #tmp select "+@idNode+" from "+@TableName+"
where ("+@idParent+" in (select "+@idNode+" from #tmp))
and ("+@idNode+" not in (select "+@idNode+" from #tmp))
set nocount off
select "+@idNode+" from #tmp order by "+@idNode+"
set nocount on
drop table #tmp
")




 
asmith   (2002-12-23 19:37) [3]

Почитай в MSSQL Server BOL статью "Expanding Hierarchies"


 
oleon   (2002-12-24 15:08) [4]

спасибо вам господа(товарищи) ...


 
oleon   (2002-12-24 15:33) [5]

Выдает такую ошибку :
Server: Msg 8101, Level 16, State 1, Line 7
An explicit value for the identity column in table "#tmp" can only be specified when a column list is used and IDENTITY_INSERT is ON.


 
sniknik ©   (2002-12-24 15:54) [6]

таблица ID, GROUPID, NAME
ID наверное Автоинкремент?

или делай в #tmp его простым числом. соответственно таблицу сначала создавать потом вместо select into insert into.
либо отключи для #tmp
SET IDENTITY_INSERT #tmp ON
(интересно пройдет для еще несозданной таблици?)


 
Polevi ©   (2002-12-24 18:15) [7]

CREATE FUNCTION AccStateIDsToTable (@ID INT)
RETURNS @T TABLE (ID INT, Level INT) AS
BEGIN
DECLARE @level INT
SET @Level=0

INSERT INTO @T (ID,Level) VALUES (@ID,0)
while exists(SELECT * FROM @T T, YourTable YT WHERE T.level=@level and YT.Owner=T.ID)
begin
INSERT @T (ID, level) SELECT YT.ID, @level+1 from @T T, YourTable YT WHERE T.level=@level and YT.Owner=T.ID
SET @level=@level+1
end

RETURN
END





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

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

Наверх




Память: 0.48 MB
Время: 0.021 c
1-62482
adolf_99
2003-01-08 18:09
2003.01.20
Помогите


14-62813
kronprince
2002-12-28 21:45
2003.01.20
Есть ли аналоги Borland Socket server ???


1-62659
lety
2003-01-09 00:22
2003.01.20
CreateProcess


1-62530
MemoryLeak
2003-01-10 19:57
2003.01.20
Нужен пример Paint`а стандартного в Windows`е...


14-62721
anpsoft
2002-12-30 01:25
2003.01.20
Development Environment for .NET on Delphi