文章详情页
mysql按照时间热度排序
浏览:167日期:2022-06-14 17:15:12
问题描述
我有一个表 有time 和 like喜欢数的总量 我想通过将 最近三天喜欢数高的 排在前面 喜欢数没有喜欢的记录表 因为是抓取的总量
我现在创建了两个表文章表id name喜欢表id 文章id ip 点赞时间id 文章id ip 点赞时间
计算喜欢表总数 假如点赞很多 很容易在喜欢表产生数千万条记录
问题解答
回答1:如果有个记录like事件的表,每like一下表里就多一条记录的话,那么很容易就能查询出最近3天like的总数了。为了提高查询效率,可以再整理出一张表,记录3天内like的总量。这道题有点跟我常出的这道面试题类似:https://segmentfault.com/q/10...我就把问题留给楼主了。我自己也多了道面试题 :-)
UPDATE
其实只需要用一张这样的表就够了:
文章id 日期 点赞数文章id 日期 点赞数
(文章id, 日期)可以作为复合主键或唯一键。每次点赞,对这篇文章当日的点赞数+1就行了,查最近三日的不就很简单又很快吗?
相关文章:
1. javascript - vue组件通过eventBus通信时,报错a.$on is not a function2. python3.x - python3.5.2安装时make报错求助3. html - vue项目中用到了elementUI问题4. javascript - 在使用 vue.js element ui的时候 怎么样保留table翻页后check的值?5. mysql_replication - mysql读写分离时如果单台写库也无法满足性能怎么解决6. ionic 项目 ionic build android -release 打包时报错7. linux - ubuntu 命令行中文 显示菱形,期望通过引入字体解决而不是zhcon这种方式8. angular.js - 如何控制ngrepeat输出的个数9. mac里的docker如何命令行开启呢?10. python - 如何用pandas处理分钟数据变成小时线?
排行榜

网公网安备