mysql按照时间热度排序
伊谢尔伦
伊谢尔伦 2017-04-17 16:31:33
[MySQL讨论组]

我有一个表 有time 和 like喜欢数的总量 我想通过将 最近三天喜欢数高的 排在前面 喜欢数没有喜欢的记录表 因为是抓取的总量

我现在创建了两个表
文章表
id name
喜欢表
id 文章id ip 点赞时间
id 文章id ip 点赞时间

计算喜欢表总数 假如点赞很多 很容易在喜欢表产生数千万条记录

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(1)
PHP中文网

如果有个记录like事件的表,每like一下表里就多一条记录的话,那么很容易就能查询出最近3天like的总数了。
为了提高查询效率,可以再整理出一张表,记录3天内like的总量。这道题有点跟我常出的这道面试题类似:
https://segmentfault.com/q/10...
我就把问题留给楼主了。我自己也多了道面试题 :-)

UPDATE

其实只需要用一张这样的表就够了:

文章id 日期 点赞数
文章id 日期 点赞数

(文章id, 日期)可以作为复合主键或唯一键。
每次点赞,对这篇文章当日的点赞数+1就行了,查最近三日的不就很简单又很快吗?

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号