例如:(以下排序均按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