您的位置:首页技术开发ASP技巧 → 用排序串字段实现树状结构(原理)

用排序串字段实现树状结构(原理)

时间:2004/11/7 4:02:00来源:本站整理作者:蓝点我要评论(0)

实现原理:以一排序字段(字符型实现排序),该字段的实际长度即为回复深度(用一位字符代表一层深度时)。

    所受限制:回复深度只受排序串定义长度的限制(有点象空间换深度),每贴回复数(包括根贴和子贴)为30左右(当sql

server使用Dictionary order,case-insensitive排序方式,即不区分字母大小写时),如果sql server使用Binary orders排

序方式时受限为127(255?)。

    改进方法:如果觉得不够用,可以使用多位字符对应一个深度(这样计算有点麻烦),或使用几位数字代表一个深度,例如3

位数字——最多可以999个子贴,不过些时排序字段的长度应为“3*最大深度”)

优点:此法是正则的——均匀的。



    有关树状结构的字段:rootid、orderstr(varchar型,按需要深度定,假如你最大要使用20层回复深度,则定为varchar

(20),余类推)



例如:(以下排序均按order by rootid+(1-sign(rootid))*lybid desc,orderstr,id desc排序)

id     rootid    orderstr

1        0        空串

2        1        z  ——回复根贴,使用串z初始化排序字串

___________________

3        1        y  ——回复1,将排在1后面的排序字符串的最后一个字符z的ascii码减1,组成新的排序串。



排序结果为:

id     rootid    orderstr

1        0        空串

3        1        y

2        1        z

___________________

4        1        x  ——回复1贴,排序字符串求法同上



排结果为:

id     rootid    orderstr

1        0        空串

4        1        x

3        1        y

2        1        z

___________________

5        1        xz ——回复4贴,检查4贴是否已经有回复,现没有,初始化排序串第二个字符(在4后加上z)



排序结果为:

id     rootid    orderstr

1        0        空串

4        1        x

5        1        xz

3        1        y

2        1        z

___________________

6        1        xy ——回复4贴,将4贴的第一子贴的排序字串最后一个字符的ascii码减1



排序结果为:

id     rootid    orderstr

1        0        空串

4        1        x

6        1        xy

5        1        xz

3        1        y

2        1        z



这样,根据orderstr和len(orderstr)——深度结合就实现了树状结构。

id        orderstr

1           空串

  4          x

    6        xy

    5        xz

  3          y

  2          z


相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 VB.NET 2005编写定时关 Jquery get/post下乱码解决方法 前台gbk gb如何使用数据绑定控件显示数据ASP脚本循环语句ASP怎么提速

人气排行 轻松解决"Server Application Error"和iis"一起学习DataGridView调整列宽用ASP随机生成文件名的函数Jquery get/post下乱码解决方法 前台gbk gbODBC Drivers错误80004005的解决办法返回UPDATE SQL语句所影响的行数的方法用Javascript隐藏超级链接的真实地址两个不同数据库表的分页显示解决方案