感覺做一個論壇不像想象中的那麼容易,但也不像想象中的那麼複雜:),經過4天的浴血奮戰,終於從對論壇製作一無所知到今天的論壇資料結構和組織形勢初步確定,中間參考了sunamd,bigeagled,廖家遠等的思路,並得到了賴皮王子,hooke,bigeagle大蝦的熱心協助,謹以此文一併表示感謝。
bigeagle的文章採用了sql資料庫的預存程序來實現,但現實中支援asp的免費網站本來就少,支援資料庫的免費網站更少,支援sql資料庫的免費網站。。。反正我沒見過,哪位知道告訴我一聲:),所以我等窮人只有用access了,我就是採用asp+access的形式實現了類似chinaasp的論壇。。閑話少說,言歸正傳。
先說一下資料庫的結構,主要有兩個表,一個儲存使用者資訊user,一個儲存論壇文章及資訊mytext。使用者資訊就不用多說了,主要就是mytext論壇文章的組織,要實現相同主題的文章組織在一塊、跟貼緊隨父貼、後發帖居上、更重要的是要認清父貼,否則會造成一層回複一律排在一起,二層回複排在一起,三層。。。如下:
根貼
回複1:根貼
回複2:根貼
回複:回複1:根貼
。。。。
所以這裡有幾個關鍵的欄位:
id(自動):自動編號(作用:顯示後來居上)
rootid(整型):根貼的id(作用:實現相同主題的文章排在一塊)
level(整型):貼子的層數(作用:顯示的時候實現縮排)
orderid(單精):相同主題文章排序的基數(作用:相同主題文章排序的先後依據,即防止出現上例的情況)
fatherid(整型):父貼id,貼子的血緣關係
排序的sql語句:
select * from mytext orderby rootid desc,orderid,id desc
實現顯示縮排(修正後的"不用遞迴實現樹形結構.."):
level=0
response.write "<ul>"
do while not rs.eof
if rs("level")<level then
for i=rs("level") to level-1
response.write "</ul>"
next
end if
if rs("level")>level then
response.write "<ul>"
end if
response.write "<li>主題:。。</li>"
level=rs("level")
rs.movenext
loop
response.write "</ul>"
%>
注意:原"不用遞迴實現樹形結構..."文章有誤,這是修改後的代碼.
另外有一點經驗要注意:就是在單精類型資料傳值的時候,如:orderid,request上來的資料要先replace(orderid," ","+"),再csng轉換,不然會報告"類型不符",我一開始百思不得其解,後來發現在傳值的時候必定會把單精資料"+"弄丟,變成空格,所以要先替換再轉型.
以上只是我個人的看法,如果有錯誤之處或有更好的方法歡迎交流gwlx@21cn.com,大家可以到211.90.159.61(開放時間:8:15~17:30)或http://www.21union.net/sqlbbs看執行個體並多多灌水呦:)..