在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美

當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

bbs樹形結構的完成辦法(一)

bbs樹形結構的完成辦法(一)

更新時間:2019-09-02 文章作者:未知 信息來源:網絡 閱讀次數:

【bigeagle】 于 2000-12-6 14:38:50 加貼在 Joy ASP ↑:

    bbs的樹形結構顯示可以有很多種方法,其中比較容易想到的是遞歸和排序串方法,但這兩種方法并不是很好,那么怎
樣才算是比較合理的算法呢?
    遞歸方法不用講,大家都知道怎么用,先講講排序串方法,最簡單的排序串方法可以這樣用,只用一個id就可以完成樹
型,向這樣
1  001
2  002
3  001001
4  001001001
5  001002001
用這個字符串排序后就變成這樣:
001
   001001
         001001001
   001002001
002
這種方法容易實現,但缺點也是很明顯,一個是回帖數受限制,另一個隨著回帖增加會越來越長,影響數據庫效率。  

下面一種方法是李龍的,屬于變通的排序串方法
DDL
--------------
CREATE TABLE dbo.Message
(
    ID          numeric(18,0) IDENTITY(1000,1),
    DateAndTime datetime      DEFAULT getdate() NOT NULL,
    AuthorID    numeric(18,0) NOT NULL,
    Subject     nvarchar(250) NOT NULL,
    Body        ntext         NULL,
    LinkURL     nvarchar(100) NULL,
    TextForLink nvarchar(50)  NULL,
    ImageURL    nvarchar(100) NULL,
    Class       int           DEFAULT 0 NOT NULL,
    ClientInfo  nvarchar(250) NULL,
    RemoteAddr  nvarchar(50)  NULL,
    CONSTRAINT PK_BBSMessage
    PRIMARY KEY NONCLUSTERED (ID,AuthorID)
)
go
CREATE TABLE dbo.MsgRefTab
(
    MsgID      numeric(18,0) NOT NULL,
    ParentID   numeric(18,0) NOT NULL,
    AncestorID numeric(18,0) NOT NULL,
    ChildNum   numeric(18,0) DEFAULT 0 NOT NULL,
    LinkStr    nvarchar(250) NOT NULL,
    CONSTRAINT PK_BBSRefTab
    PRIMARY KEY NONCLUSTERED (MsgID)
)
go
-----------------
存儲過程:
-----------------
-- 抽出
CREATE PROCEDURE sp_Summary
@HaveBody bit,
@from numeric,
@to numeric
AS
IF (@HaveBody = 1)
select t.ID,t.DateAndTime,m.Nickname as
Author,m.Email,t.Subject,t.Body,t.LinkURL,t.TextForLink,t.ImageURL,s.ChildNu
m,s.ParentID
from Message t
  ,MsgRefTab AS s
  ,(SELECT MsgID FROM MsgRefTab WHERE ParentID = 0) AS f
  ,Members AS m
where t.ID=s.MsgID
  and f.MsgID = s.AncestorID
  and f.MsgID between @from and @to
  and m.MemberID = t.AuthorID
order by s.AncestorID,s.LinkStr
ELSE
select t.ID,t.DateAndTime,m.Nickname as
Author,m.Email,t.Subject,t.LinkURL,t.TextForLink,t.ImageURL,s.ChildNum,s.Par
entID
from Message t
  ,MsgRefTab AS s
  ,(SELECT MsgID FROM MsgRefTab WHERE ParentID = 0) AS f
  ,Members AS m
where t.ID=s.MsgID
  and f.MsgID = s.AncestorID
  and f.MsgID between @from and @to
  and m.MemberID = t.AuthorID
order by s.AncestorID,s.LinkStr
go

-- 加貼

CREATE PROCEDURE sp_Add_Message
@AuthorID numeric,
@Subject nvarchar(250),
@Body  ntext,
@LinkURL nvarchar(100),
@TextForLink nvarchar(50),
@ImageURL nvarchar(100),
@ParentID numeric,
@ID  numeric OUTPUT,
@ChildNum numeric OUTPUT,
@LinkStr nvarchar(250) OUTPUT,
@AncestorID numeric OUTPUT
AS
INSERT INTO Message(
  AuthorID,
  Subject,
  Body,
  LinkURL,
  TextForLink,
  ImageURL)
VALUES(
  @AuthorID,
  @Subject,
  @Body,
  @LinkURL,
  @TextForLink,
  @ImageURL)

SELECT @ID = @@IDENTITY

UPDATE MsgRefTab
SET
  ChildNum = ChildNum+1
WHERE
  MsgID = @ParentID

SELECT @ChildNum = ChildNum,
  @LinkStr = LinkStr,
  @AncestorID = AncestorID
FROM MsgRefTab
WHERE
  MsgID = @ParentID
go

---
是基于這樣的想法:
貼子和跟貼都放在message表里,另有MsgRefTab對每一條信息都有描述。
父貼ParentID,0為不是子貼
祖宗貼AncestorID
直接跟貼數ChildNum
聯接串LinkStr,學問都在這里,所有的跟貼都用一個數字字符串表示
如是
1011--->            為空
1012--->001         1011的跟貼,父貼LinkStr+父貼的子貼數+1
1013--->001001      1012的跟貼,父貼LinkStr+父貼的子貼數+1
1018--->001001001   1013的跟貼,父貼LinkStr+父貼的子貼數+1
1014--->001002      1012的跟貼,父貼LinkStr+父貼的子貼數+1
1017--->001002001   1014的跟貼,父貼LinkStr+父貼的子貼數+1

部分演示數據:
MsgID ParentID AncestorID ChildNum LinkStr
1010  0        1010       0
1011  0        1011       1
1012  1011     1011       3        001
1013  1012     1011       1        001001
1014  1012     1011       1        001002
1015  0        1015       0
1017  1014     1011       0        001002001
1018  1013     1011       0        001001001

就是算法復雜一點,但只使用select就得到了正確的結構列表。
看了這么多bbs的算法,還是覺得自己的方法好,現實中由存儲過程直接生成xml文檔,交
給client。



溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美
  • <li id="86scu"><menu id="86scu"></menu></li>
    <li id="86scu"></li>
    <button id="86scu"></button>
  • <s id="86scu"></s><button id="86scu"><menu id="86scu"></menu></button>
  • 好色先生视频污| a级片一区二区| 日韩a级黄色片| 三级黄色片播放| 亚洲精品20p| 在线观看免费av网址| 午夜欧美福利视频| 国产情侣av自拍| aa免费在线观看| 日本成人中文字幕在线| 成人性生生活性生交12| 手机看片福利日韩| 亚洲天堂av一区二区三区| 久久久久久久久久一区| 亚洲色图偷拍视频| 久久久天堂国产精品| 成人免费a级片| 播放灌醉水嫩大学生国内精品| 亚洲熟妇无码一区二区三区| 成人黄色av片| 久久99爱视频| 免费cad大片在线观看| 久久久久免费看黄a片app| 激情综合在线观看| 亚洲男人天堂av在线| 美女黄色片网站| 中文字幕日本最新乱码视频| 国产又黄又猛又粗又爽的视频| 一级片黄色免费| 欧美不卡在线播放| 亚欧激情乱码久久久久久久久| 在线无限看免费粉色视频| 成人一区二区免费视频| 欧美性猛交久久久乱大交小说| 自拍一级黄色片| 日本三级免费观看| 中国黄色录像片| 91香蕉视频污版| 日韩小视频在线播放| 亚洲va综合va国产va中文| 国产女主播自拍| 国产精品自在自线| 久久综合久久色| 国产精品久久久久久久乖乖| 亚欧激情乱码久久久久久久久| 成年人网站国产| 亚洲一二三不卡| 一本色道无码道dvd在线观看| 日本a级片在线观看| 手机看片一级片| 国产又黄又猛视频| 分分操这里只有精品| 爱爱爱视频网站| 国产亚洲视频一区| 99久久国产宗和精品1上映| youjizz.com在线观看| 国产精品99久久久久久大便| 男女污污的视频| 四季av一区二区| 中文字幕无码不卡免费视频| 中国丰满熟妇xxxx性| 男人天堂网站在线| 日本一本草久p| 欧美日韩在线免费观看视频| 网站一区二区三区| 少妇一级淫免费放| 天堂社区在线视频| 国产高潮免费视频| 色播五月综合网| 国产色视频在线播放| 手机在线免费观看毛片| 青青草原av在线播放| 男女午夜激情视频| 国产精品沙发午睡系列| 熟女少妇在线视频播放| 久草热视频在线观看| 91av在线免费播放| 成人日韩在线视频| 亚洲美女自拍偷拍| 国产片侵犯亲女视频播放| 亚洲色欲久久久综合网东京热| 日韩一级性生活片| 激情内射人妻1区2区3区| 另类小说第一页| 久久久久xxxx| 成人黄色片免费| 99精品人妻少妇一区二区| 国产成人综合一区| 九九热视频免费| 人妻无码久久一区二区三区免费| 日韩伦理在线免费观看| 成人精品小视频| 国产精品igao网网址不卡| 国产va亚洲va在线va| 日本激情综合网| 国产a级黄色大片| 韩国中文字幕av| 欧美一级中文字幕| 亚洲最大成人在线观看| 男女爱爱视频网站| www.xxx亚洲| www.男人天堂网| 亚洲这里只有精品| 国产特级淫片高清视频| 国产成人在线综合| 黄色一级视频片| 免费cad大片在线观看| 国产又大又黄又粗又爽| av在线观看地址| 久久久一二三四| 国产小视频精品| 久久久久久久午夜| 蜜臀av性久久久久蜜臀av| 亚洲第一狼人区| 成人在线观看a| 国产欧美日韩网站| 欧美一区二区三区综合| 亚洲天堂av线| 91av资源网| 成人黄色av片| 成人免费网站入口| 永久免费网站视频在线观看| 午夜免费高清视频| 凹凸日日摸日日碰夜夜爽1| 福利视频一二区| 波多野结衣综合网| 久久天天东北熟女毛茸茸| 国产毛片久久久久久| av污在线观看| 99精品免费在线观看| 阿v天堂2017| 久久精品国产精品亚洲色婷婷| 嫩草影院中文字幕| 日本香蕉视频在线观看| 男同互操gay射视频在线看| 中文字幕丰满乱码| 九九久久久久久| 一区二区三区四区久久| 中文字幕第22页| 91传媒免费视频| 成人午夜免费在线视频| 成人午夜免费在线视频| 波多野结衣综合网| 99久久激情视频| 999在线观看| www.日本久久| 日韩伦理在线免费观看| 亚洲欧洲日产国码无码久久99| 久久久噜噜噜www成人网| 搡女人真爽免费午夜网站| 成人亚洲免费视频| 久久在线中文字幕| 国产91对白刺激露脸在线观看| www.天天射.com| 天天做天天爱天天高潮| 国产天堂视频在线观看| 欧美 日韩精品| 欧美特级aaa| 蜜臀av性久久久久蜜臀av| 久久久久久久久久久99| 久色视频在线播放| 亚洲精品免费一区亚洲精品免费精品一区 | 永久免费黄色片| 日韩精品综合在线| caoporn超碰97| 青青在线免费视频| 亚洲欧洲日产国码无码久久99| 冲田杏梨av在线| 青草网在线观看| 国产三级三级看三级| 日韩精品在线视频免费观看| 欧美伦理视频在线观看| 欧美精品在欧美一区二区| 男人搞女人网站| cao在线观看| 日韩欧美中文在线视频| 精品99在线视频| 免费的一级黄色片| 免费黄频在线观看| 日本xxxxxxx免费视频| 久久久天堂国产精品| 天天操天天摸天天爽| 日韩黄色短视频| 亚洲天堂第一区| 在线观看免费视频污| 黄色免费网址大全| 国产黄色特级片| 日本www在线播放| 丰满少妇大力进入| 99热这里只有精品免费| 九九久久久久久| 日韩av加勒比| 999在线观看| 在线观看免费av网址| 免费黄色一级网站| 国产福利一区视频| 日韩av在线综合| 国模杨依粉嫩蝴蝶150p| 99热自拍偷拍| 91av俱乐部|