亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

bbs樹形結構的實現方法(一)

2019-11-18 21:44:48
字體:
來源:轉載
供稿:網友
【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网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人av.网址在线网站| 日韩小视频在线| 久久久精品在线| 欧美精品少妇videofree| 欧美在线亚洲在线| 欧美电影在线播放| 亚洲精品视频在线观看视频| 91日韩在线视频| 欧美区二区三区| 国产热re99久久6国产精品| 91高清在线免费观看| 国产精品手机播放| 国内精品免费午夜毛片| 久久久亚洲国产| 国产精品视频白浆免费视频| 91美女片黄在线观| 欧美性xxxx极品hd满灌| 91久久精品视频| 久久99热这里只有精品国产| 国产激情久久久| 97久久精品人人澡人人爽缅北| 日韩欧美aⅴ综合网站发布| 国产aaa精品| 亚洲综合在线做性| 久久久久女教师免费一区| 久久综合久久美利坚合众国| 国产婷婷色综合av蜜臀av| 国产精品电影在线观看| 91视频8mav| 亚洲视频在线播放| 日韩av免费一区| 欧美日韩精品在线播放| 美女视频黄免费的亚洲男人天堂| 久久69精品久久久久久国产越南| 4438全国成人免费| 欧美日韩亚洲91| 成人免费视频在线观看超级碰| 国产精品久久久久免费a∨大胸| 欧美性猛交xxxxx免费看| 亚洲国产日韩一区| 精品亚洲一区二区三区在线播放| 亚洲精品视频在线观看视频| 亚洲人成五月天| 亚洲最大激情中文字幕| 俺去了亚洲欧美日韩| 欧美电影免费观看高清| 亚洲老头同性xxxxx| 亚洲精品白浆高清久久久久久| 91亚洲精品一区二区| 国产第一区电影| 欧美天堂在线观看| 色综合伊人色综合网| 最近2019中文字幕第三页视频| 亚洲最大成人在线| 久久中文字幕在线| 91九色蝌蚪国产| 成人h猎奇视频网站| 日韩精品在线观看网站| 日韩在线观看精品| 欧美激情精品久久久久| 欧美激情va永久在线播放| 狠狠综合久久av一区二区小说| 性欧美亚洲xxxx乳在线观看| 欧美日本中文字幕| 亚洲人成免费电影| 一本色道久久综合狠狠躁篇怎么玩| 国产精品扒开腿做爽爽爽的视频| 国产成人精品久久| 亚洲伊人成综合成人网| 成人国产精品免费视频| 国内精品久久久久影院 日本资源| 亚洲精品国精品久久99热一| 高清欧美电影在线| 成人h视频在线观看播放| 亚洲成人精品av| 国产成人福利夜色影视| 国产精品视频不卡| 日本精品一区二区三区在线| 日韩性xxxx爱| 伊人亚洲福利一区二区三区| 2018国产精品视频| 亚洲精品久久久久中文字幕二区| 亚洲xxxx做受欧美| 欧美又大又粗又长| 国产高清视频一区三区| 中文字幕久精品免费视频| 精品在线观看国产| 久久男人资源视频| 韩国精品久久久999| 国产欧美日韩丝袜精品一区| 欧美精品在线网站| 日韩在线观看免费网站| 亚洲一级免费视频| 成人在线视频网站| 亚洲欧美日本伦理| 欧美性高跟鞋xxxxhd| 亚洲第一页在线| 亚洲精品98久久久久久中文字幕| 国产精品久久久久久久av电影| 91精品视频在线播放| 日韩视频在线免费观看| 国产激情久久久久| 国产成人精品999| 国产亚洲欧美日韩一区二区| 欧美xxxx14xxxxx性爽| 中日韩美女免费视频网址在线观看| 欧美日韩中文字幕在线视频| 91免费看国产| 欧美超级乱淫片喷水| 精品久久久久久国产| 欧美精品久久久久久久久久| xxxxx91麻豆| 亚洲天堂av高清| 国产精品av电影| 91精品久久久久久久久中文字幕| 日韩电影免费观看中文字幕| 亚洲欧美色婷婷| 亚洲精品大尺度| 91久久精品在线| 亚洲欧美制服综合另类| 亚洲福利在线观看| 欧美大全免费观看电视剧大泉洋| 久久久久久久久久久免费| 亚洲免费一级电影| 综合网日日天干夜夜久久| 日av在线播放中文不卡| 九色成人免费视频| 欧美激情亚洲另类| 国模视频一区二区三区| 亚洲精品日韩在线| 国产精品大陆在线观看| 欧美大奶子在线| 最近日韩中文字幕中文| 中文字幕少妇一区二区三区| 蜜臀久久99精品久久久无需会员| 欧美激情亚洲综合一区| 自拍偷拍亚洲在线| 91网站免费看| 成人激情免费在线| 亚洲精品乱码久久久久久金桔影视| 91亚洲精品视频| 亚州精品天堂中文字幕| 国产精品久久久久久久久影视| 国产精品91在线观看| 久久精品国产96久久久香蕉| 一区二区三区无码高清视频| 亚洲国产精品久久久久久| 国产精品xxx视频| 日韩在线免费视频| 日韩精品极品毛片系列视频| 久久亚洲精品毛片| 综合网中文字幕| 亚洲自拍偷拍色图| 欧美激情精品久久久久久变态| 久久网福利资源网站| 久久精品免费播放| 国产婷婷成人久久av免费高清| 国产精品自在线| 欧美色道久久88综合亚洲精品| 91久久精品日日躁夜夜躁国产| 国产成人综合精品| 欧美视频在线免费| 亚洲国产精品久久久久秋霞蜜臀| 97高清免费视频|