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

  • 来源: 互联网 作者: 若水   2008-03-17/13:06
  • 实现原理:以一排序字段(字符型实现排序),该字段的实际长度即为回复深度(用一位字符代表一层深度时)。
        所受限制:回复深度只受排序串定义长度的限制(有点象空间换深度),每贴回复数(包括根贴和子贴)为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



    评论 {{userinfo.comments}}

    {{money}}

    {{question.question}}

    A {{question.A}}
    B {{question.B}}
    C {{question.C}}
    D {{question.D}}
    提交

    驱动号 更多