大鷹,關于你在精華區的樹狀結構存儲過程的貼子的內容好像不對呀,我做了實驗,只能取根帖,我改了一下,在query analyzer中可以,但在頁面上只能顯示出一部分,你幫忙看一下好嗎 CREATE proc up_TopicList @a_ForumID int ,@a_intPageNo int , @a_intPageSize tinyint as declare @m_intRecordNumber int declare @m_intStartRecordint declare @m_intRootIDint select @m_intRecordNumber = @a_intPageSize * @a_intPageNo select @m_intStartRecord = @a_intPageSize * (@a_intPageNo - 1) + 1
/*求符合條件記錄數*/ select "RecordCount" = count(*) from BBS where Layer=1 and ForumID = @a_ForumID
/*輸出紀錄*/ /*首先定義可滾動光標*/ set rowcount @m_intRecordNumber declare m_curTemp Scroll cursor for select 'rootID'=a.rootID from BBS as a join BBSUser as d on a.UserID = d.[ID] where a.Layer=1 and a.ForumID = @a_ForumID order by RootID desc , Layer , PostTime desc open m_curTemp fetch absolute @m_intStartRecord from m_curTemp into @m_intRootID while(@@fetch_status = 0) begin select 'ID' = a.[ID] , 'Title' = a.Title , 'UserName' = d.UserName , 'Hits' = a.Hits, 'Face' = a.Face , 'Layer'=a.Layer, 'ContentSize' = datalength(a.Content) , 'TotalChilds' = (select sum(TotalChilds) from BBS as b where a.RootID = b.RootID) , 'LastReplyTime' = a.PostTime from BBS as a join BBSUser as d on a.UserID = d.[ID] where a.Layer>=1 and a.ForumID = @a_ForumID and a.rootID=@m_intRootID order by RootID desc , Layer , PostTime desc fetch next from m_curTemp into @m_intRootID end set rowcount 0 /*清場*/ CLOSE m_curTemp DEALLOCATE m_curTemp GO
|