Reply to Re: Recursive Stored Procedure?

Your name:

Reply:


Posted by Bill on 10/16/06 18:26

Henrik,

I just answered a similar question and have copied the text to this
chain. See if it applies to answer your question.

--DDL and inserts to test:
CREATE TABLE [dbo].[tblCategory](
[categoryid] [int] NOT NULL,
[parentid] [int] NOT NULL,
[description] [varchar](50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT
NULL
)
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
1, 0, 'Computers')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
4, 1, 'PC Components')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
5, 1, 'Storage')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
6, 1, 'Laptops')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
7, 1, 'Desktops')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
8, 1, 'Components')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
9, 4, 'CPUs')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
10, 4, 'Sound Cards')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
11, 4, 'Video Cards')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
12, 9, 'AMD')
INSERT INTO tblCategory ( categoryid, parentid, description ) VALUES (
13, 9, 'Intel')

--Procedure to recursively get all subnodes

Create PROCEDURE getTblCategory

AS
DECLARE @tbls_to_join int
DECLARE @selectCmd varchar(1000)
DECLARE @tblCmd varchar(4000)
DECLARE @cmd varchar(8000)
DECLARE @loop_count int

SET @loop_count = 1

SET @selectCmd = 'SELECT t1.categoryid, t1.parentid, t1.description'
SET @tblCmd = 'FROM tblCategory t1 '

SELECT @tbls_to_join = count(distinct parentid) FROM tblCategory

WHILE @loop_count < @tbls_to_join
BEGIN
SET @loop_count = @loop_count + 1
SET @tblCmd = @tblCmd + char(10) + 'LEFT OUTER JOIN tblCategory t' +
convert(varchar,@loop_count) + char(10)
+ 'ON t' + convert(varchar,@loop_count - 1) + '.categoryid
= t' + convert(varchar,@loop_count) + '.parentid'
SET @selectCmd = @selectCmd + char(10) + ', t' +
convert(varchar,@loop_count)
+ '.categoryid, t' + convert(varchar,@loop_count)
+ '.parentid, t' + convert(varchar,@loop_count) +
'.description'
END

SELECT @cmd = @selectCmd + char(10) + @tblCmd
PRINT @cmd

EXEC (@cmd)

Henrik Juul wrote:
> Thanx Kristian.
>
> Can you show me how??
>
> Regards
> Henrik
> "Kristian Damm Jensen" <kristiandamm@mail.dk> wrote in message
> news:45336c4f$0$904$edfadb0f@dread12.news.tele.dk...
> > Henrik Juul wrote:
> >> How do I call my Stored Procedure recursively:
> >>
> >> CREATE PROCEDURE dbo.GetParentIONode
> >> (
> >> @IONodeID int,
> >> @FullNodeAddress char(100) OUTPUT
> >> )
> >>
> >> AS
> >> BEGIN
> >> DECLARE @ParentIONodeID int
> >> IF EXISTS (SELECT ParentIONodeID FROM IONodes WHERE IONodeID =
> >> @IONodeID) BEGIN
> >> SET @FullNodeAddress = CAST((SELECT ParentIONodeID FROM IONodes WHERE
> >> IONodeID = @IONodeID) AS VARCHAR) + ' / ' + @FullNodeAddress
> >> --CALL SP Again with @ParentIONodeID and @FullNodeAddress until
> >> ParentIONodeID = NULL
> >> SELECT @FullNodeAddress
> >> END
> >> END
> >> GO
> >
> > Like you would call any other stored procedure. But you can't use the
> > result set from a stored procedure directly in your where clause. You have
> > to store it in a temptable.
> >
> > --
> > Regards,
> > Kristian Damm Jensen
> > "This isn't Jeopardy. Answer below the question."
> >

[Back to original message]


Удаленная работа для программистов  •  Как заработать на Google AdSense  •  England, UK  •  статьи на английском  •  PHP MySQL CMS Apache Oscommerce  •  Online Business Knowledge Base  •  DVD MP3 AVI MP4 players codecs conversion help
Home  •  Search  •  Site Map  •  Set as Homepage  •  Add to Favourites

Copyright © 2005-2006 Powered by Custom PHP Programming

Сайт изготовлен в Студии Валентина Петручека
изготовление и поддержка веб-сайтов, разработка программного обеспечения, поисковая оптимизация