数据库设计中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
