大鹰,关于你在精华区的树状结构存储过程的贴子的内容好像不对呀,我做了实验,只能取根帖,我改了一下,在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
……