中国站长下载-为中国站长提供最好最全的建站资源! 首 页发布资源有事留言繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:中国站长下载 -> 文章中心 -> 网页编程 -> ASP编程 -> 文章内容  虚拟主机 域名注册 退出登录 用户管理
栏目导航
· ASP编程 · .NET编程
· PHP编程 · JSP编程
· CGI 专区
热门文章
· sndvol32 - sndvol3...
· [组图] FLASH:《大话李白》...
· 个人网站到底能赚多...
· [图文] Rundll.exe是病毒吗...
· [组图] Flash:制作MV
· 价值12万元的网站SE...
· 网站创业者,你需要...
· 一个成功的网站设计...
· [图文] FLASH:韩国导航条解...
· 中国网站的赚钱模式...
相关文章
· bbs的数据结构和存储...
· bbs的数据结构和存储...
· bbs的数据结构和存储...
bbs的树状结构算法
作者:不详  来源:不详  发布时间:2006-8-13 0:40:03  发布人:chinazhan

 减小字体 增大字体

     数据库设计中order_value是用来排序的,具体实现是
  **注意以下的讨论是对一个主题而言,就是对一棵树而言!
  如果加一新贴那么 order_value=0
  如果跟贴查比父贴 order_value大的order_value
  如果有假设为next_value,那么新帖的
  order_value为父贴的(order_value+next_value)/2;
  如果有那么新帖的order_value为父贴的order_value+1000
  也就是说如果对A贴跟贴,如果A为末贴,A的字帖的order_value为order_value(父)+1000,
  不是末贴既找出比A大的order_value,新的order_value为两者的一半!
  排序实现: order by groupid,order_value desc
  **技巧如果想实现层次多一点可以每次加的多一点+100000,那样应该会好一点
  
  ***不足之处:
  1:使用两个字段排序,速度有点慢
  2:使用order_value是一个浮点数,使用float估计不够,还是使用double
  3:只能实现理论上的无穷层实际上超过10层使用float有问题,使用double可能没有
  4:插入是需要查找下一个order_value
  
  Dim ordervalue, nextvalue As Double
  sql = "select gorders where gId=" & gId & " and goders> " & gorders & " order by goders "
  rs1.Open sql, conn1, adOpenForwardOnly, adLockOptimistic '查询比父贴大的
   order_value
  If (rs1.EOF And rs1.BOF) Then
   gorders = gorders + 256
   gLayer = gLayer + 1
  Else
   nextvalue = rs1("gorders")
   If (nextvalue - gorders) > 1 Then
   gorders = Int((gorders + nextvalue) / 2)
   gLayer = gLayer
   Else
   'gorders,glayer跟回帖一样
  End If
  End If
  
  End Sub
  
  
    做人要厚道,请注明转自chinazhan中国站长(www.ChinaZhan.com)。

 
[] [返回上一页] [打 印] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
中国站长下载
中国站长下载

本页只接受PR>=4 IT类站点连接,申请连接,谢谢您们的支持!希望我们的下载站能够真正帮到中国的站长们!
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图
Copyright © 2005-2006 ChinaZhan.Net. All Rights Reserved .