論壇樹狀記錄表的堆棧展開
發(fā)表時間:2023-08-05 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]由于工作原因,涉及到一個樹狀存放記錄的表,要求程序中把樹狀表全部展開,并輸出相應(yīng)的數(shù)據(jù)內(nèi)容。由于涉及到此種操作的地方很多,比如網(wǎng)絡(luò)上的\\\"論壇"就是典型的采用樹狀存放記錄的表...
由于工作原因,涉及到一個樹狀存放記錄的表,要求程序中把樹狀表全部展開,并輸出相應(yīng)的數(shù)據(jù)內(nèi)容。由于涉及到此種操作的地方很多,比如網(wǎng)絡(luò)上的\\\"論壇"就是典型的采用樹狀存放記錄的表,特此整理出來與大家分享。
在很多資料都有介紹展開樹狀記錄的程序,但是很多是采用遞歸的方法。我們知道,遞歸的方法邏輯比較簡單,實際操作起來比較容易。但是遞歸有一個最大的缺點就是占用資源太多,速度太慢。如果在互聯(lián)網(wǎng)的"論壇"上采用此種方法,在表記錄很多的情況下將是一個非常嚴(yán)重的問題。下面的程序在筆者的工作中解決了一個大問題并將應(yīng)用于本人小站(yuking.126.com)的論壇。
我這里采用速度非常快的堆棧來實現(xiàn)這種操作,但是操作起來相對而言難度加大。我們就以論壇記錄表為例講解這一過程,首先了解一下表結(jié)構(gòu):
一、表結(jié)構(gòu)(article)
self int '本記錄ID號
father int '父記錄ID號
title char '貼子標(biāo)題
author char '貼子作者
datetime date '發(fā)貼日期時間
hits int '點擊數(shù)
reply int '回復(fù)數(shù)
..... '根據(jù)具體的情況我們還可以有更多的字段
1)關(guān)鍵說明:self是記錄本記錄的ID號,這應(yīng)該是一個自動增長的字段,不充許重復(fù)。father是記錄本結(jié)點的父結(jié)點ID號的字段,若該記錄內(nèi)容為"回貼"此字段值應(yīng)該為"主貼"的ID號。若該記錄為"主貼"則它的父結(jié)點應(yīng)該為"0"
2)如下兩條記錄是父子記錄:
self father title author .....
1 0 '誰能幫幫我' '三腳貓'
2 1 '我能幫你什么忙嗎?' '網(wǎng)上飛'
二、操作方法
首先,我們讀出所有父結(jié)點為"0"的記錄也就是"主貼",統(tǒng)統(tǒng)放入堆棧中。然后輸出位于棧頂?shù)囊粭l記錄("主貼")數(shù)據(jù),并清空棧頂,棧頂下移一格。接著查找所有父結(jié)點為該棧項結(jié)點("主貼")的記錄("回貼"),也統(tǒng)統(tǒng)放于棧頂。注意到?jīng)]有,就這兩步我們就完成了把一條父記錄輸出并展開其子結(jié)點的工作。余下的工作只是依次類推而已了,直到棧為空為止。
當(dāng)然實際操作時可能還會有一些要求,比如要求得到記錄的層數(shù),回復(fù)數(shù)等等問題,我們只需稍加改進(jìn)就能實現(xiàn)。
三、這里是整理后的原代碼
<%
set RS=server.CreateObject("ADODB.Recordset")
sql_text="select * from article where father=0 order by datetime desc"
RS.Open sql_text,Bbs_ConnectionString '查找所有父結(jié)點為'0'的結(jié)點,即"主貼"。
Dim Stack(100,8) '定義堆棧,我這里是100('8'是指每個棧元素分別存放8個字段值)。'可根據(jù)實際情況定義堆棧大小,可以按這個公式計算"最多層數(shù)*最多展開數(shù)"。
while not Rs.eof
Stack(0,0)=RS("self")
Stack(0,1)=RS("father")
Stack(0,2)=RS("title")
Stack(0,3)=RS("author")
Stack(0,4)=RS("datetime")
Stack(0,5)=RS("hits")
Stack(0,6)=RS("reply")
Stack(0,7)=0
Top=1
do until Top=0
Sql_text="select * from article where father="&StackTop&"
RS1.Open Sql_text,MyConn '查找所有父結(jié)點為棧頂結(jié)點的記錄
'輸出棧項元素,我這里是直接輸出,實際做的時候可以產(chǎn)生表格等等效果
for i=0 to 7
Response.write stack(top-1,i)
next
ParentLevel=stack(top-1,7) '清空堆棧之前獲得父記錄的層數(shù)
for i=0 to 7 '清空堆棧項部
Stack(top-1,i)=""
next
Top=top-1 '棧頂向下移動一格
'將查找到的棧項結(jié)點"派生出"的全部子記錄存入堆棧
While not RS1.eof
Stack(Top,0)=RS1("self")
Stack(Top,1)=RS1("father")
Stack(Top,2)=RS1("title")
Stack(Top,3)=RS1("author")
Stack(Top,4)=RS1("datetime")
Stack(Top,5)=RS1("hits")
Stack(Top,6)=RS1("reply")
Stack(Top,7)=ParentLevel+1
Rs1.movenext
Top=Top+1 '棧項向上移動
Wend
Rs1.close
loop
Rs.MoveNext '移動到下一條記錄
Wend
Rs.close
set Rs=nothing
set Rs1=nothing
%>