Главная страница
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.029 c
3-62400
an
2002-12-25 16:02
2003.01.20
Проблемма с DbCtrlGrid


1-62487
ЮРИЙ_К
2003-01-10 11:54
2003.01.20
Хинт в трэе под ХР ???


7-62886
Sergei_tlt
2002-11-06 11:52
2003.01.20
Перемещение мыши


1-62520
Ag2002
2003-01-10 10:58
2003.01.20
Изменение значения


4-62939
Kiril45
2002-12-06 02:19
2003.01.20
Как узнать что в другом приложении нажата кнопка