文章詳情頁
mysql按照時間熱度排序
瀏覽:82日期: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. mysql - 如何減少使用或者不用LEFT JOIN查詢?2. mysql - jdbc的問題3. Python爬蟲如何爬取span和span中間的內容并分別存入字典里?4. python - 我在使用pip install -r requirements.txt下載時,為什么部分能下載,部分不能下載5. 視頻文件不能播放,怎么辦?6. python - Scrapy存在內存泄漏的問題。7. html5 - H5 audio 微信端 在IOS上不能播放音樂8. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處9. python - 編碼問題求助10. mysql - 千萬級數據的表,添加unique約束,insert會不會很慢?
排行榜
