若数据表(info)有如下字段:
id subject message dateline replies views istop
主题 信息 时间 回复 点击数 是否推荐
如何赛选出15天(半个月)内最值得查看/推荐的信息?
一般写法是:
以上赛选出来的信息,会有一个严重的BUG错误,也就是
replies 和 views 越大 越会排在前面,越往前排,replies 和 views 将会越大,所以这是一个正比,同时这样的操作将对其他信息产生不公正的影响。
现在,求一个ORDER BY 公式不因为replies 和 views 越大而越靠前的算法,
目前我能想到的是:LOG对数函数,对数不会因为replies和views越大而越大。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
比如通过一个时间字段也可以做到和这个比较相似。不过我想推荐是我的一个做法就是建一个字段。加上自己一个算法得出一个数直然后order by 字段 desc limit 15
。这样子。我认为是比较高效的。