在线看毛片视频-国产免费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>
  • 国产偷人视频免费| 国产97色在线 | 日韩| 91国在线高清视频| 97超碰在线视| 欧美精品久久久久久久免费| av7777777| 邪恶网站在线观看| 26uuu成人| 国产成人无码精品久久久性色| 成年人在线看片| 国产福利精品一区二区三区| 国产免费一区二区三区四在线播放| 欧洲xxxxx| 91黄色小网站| 国产又爽又黄ai换脸| 国产精品自拍片| 尤物国产在线观看| av网站大全免费| 天天色综合社区| av在线播放天堂| 亚洲免费999| 欧美一级视频免费看| 日本人69视频| 777av视频| 五月天六月丁香| 999香蕉视频| av在线免费观看国产| 91视频免费版污| 2018国产在线| 尤物网站在线看| www.超碰com| 日韩在线观看a| 天堂网成人在线| 99视频在线视频| 欧美日韩亚洲一| 久久久久久久香蕉| theporn国产精品| 麻豆传传媒久久久爱| 欧美视频免费看欧美视频| 三年中文在线观看免费大全中国| 女人扒开屁股爽桶30分钟| 中国一级黄色录像| 中文av字幕在线观看| 最近免费中文字幕中文高清百度| 日韩亚洲欧美视频| youjizz.com在线观看| 日本一区二区免费高清视频| 天天操天天干天天做| 无码人妻精品一区二区三区66| 成人黄色av片| 黄色大片中文字幕| 91精品国产91久久久久麻豆 主演| 婷婷激情小说网| 亚洲精品免费一区亚洲精品免费精品一区 | www.成人黄色| 岛国毛片在线播放| 网站一区二区三区| 国产又大又黄又粗的视频| 91黄色小网站| 97在线免费公开视频| 六月丁香婷婷在线| 成人观看免费完整观看| 精品国产免费av| 日本精品一区在线观看| 六月丁香婷婷激情| aaa毛片在线观看| 国产xxxxx视频| 亚洲综合欧美激情| 99视频在线观看视频| 午夜xxxxx| 国产日韩第一页| 亚洲一区 在线播放| 日韩激情视频一区二区| 波多野结衣家庭教师在线播放| 国产在线精品91| 中文字幕第36页| 一级 黄 色 片一| 欧美a级免费视频| 国产中文字幕免费观看| 男女视频一区二区三区| 少妇一级淫免费播放| 18视频在线观看娇喘| 日本a视频在线观看| 91黄色小网站| 成年人网站av| 人人干视频在线| 日韩欧美国产片| 亚洲精品国产suv一区88| 日韩小视频在线播放| 欧美特级aaa| cao在线观看| 中文字幕22页| 欧美一级视频免费看| 999精彩视频| r级无码视频在线观看| 校园春色 亚洲色图| 激情五月婷婷六月| 欧美大尺度做爰床戏| 国产美女主播在线播放| 污网站在线免费| 蜜桃传媒一区二区三区| 三日本三级少妇三级99| 国产美女网站在线观看| 爽爽爽在线观看| www.国产区| 久久99久久99精品| 亚洲欧美天堂在线| 国产视频一区二区视频| 免费视频爱爱太爽了| 99中文字幕在线| 黄色成人免费看| 欧美色图色综合| 日韩精品一区二区免费| 涩涩网站在线看| 久久这里只精品| 精品免费国产一区二区| 被灌满精子的波多野结衣| 久久精品一卡二卡| 天天干天天爽天天射| 免费日韩视频在线观看| av无码久久久久久不卡网站| 国产奶头好大揉着好爽视频| 15—17女人毛片| 国产性生交xxxxx免费| www.中文字幕在线| 国产va亚洲va在线va| av影院在线播放| 国产大尺度在线观看| 香蕉视频xxx| 黄色aaaaaa| 一级黄色免费在线观看| 99九九精品视频| 亚洲精品www.| caoporm在线视频| 欧美又黄又嫩大片a级| 最新av免费在线观看| 亚洲欧美日本一区二区| www.五月天色| 黄黄视频在线观看| 免费高清一区二区三区| 青草视频在线观看视频| 免费超爽大片黄| 亚洲不卡中文字幕无码| 欧美精品99久久| 一本久道综合色婷婷五月| 欧美精品无码一区二区三区| 日本www.色| 人人爽人人爽av| 免费观看亚洲视频| 国产a级片网站| 免费激情视频在线观看| 欧美第一页浮力影院| 亚洲综合20p| 成人免费看片'免费看| 日韩小视频在线播放| 午夜激情福利在线| 欧美性视频在线播放| 日本一区午夜艳熟免费| 男人的天堂日韩| 手机av在线网站| 精品久久一二三| 中文av字幕在线观看| 男人添女人荫蒂免费视频| 色一情一乱一伦一区二区三区日本| 岛国毛片在线播放| 欧美亚洲黄色片| 在线观看岛国av| aa视频在线播放| 911福利视频| 无罩大乳的熟妇正在播放| 一本岛在线视频| 青青草精品视频在线| 极品粉嫩美女露脸啪啪| www..com日韩| 国产不卡的av| 动漫av免费观看| av影院在线播放| 国产日韩欧美久久| 婷婷无套内射影院| 中文字幕亚洲影院| av免费中文字幕| av在线免费观看国产| 视频在线观看免费高清| 国产伦精品一区二区三区四区视频_| 乌克兰美女av| 中国丰满人妻videoshd| 国产精品久久久影院| 在线观看的毛片| 99热自拍偷拍| 青青青青在线视频| 亚洲一二区在线观看| 看欧美ab黄色大片视频免费| 男人的天堂狠狠干| 精品无码av无码免费专区| av中文字幕网址| 欧美伦理片在线观看| 日本精品免费在线观看| 无码 制服 丝袜 国产 另类| 最新黄色av网站| 日本网站在线看|