文章詳情頁
mysql分表之后怎么查詢
瀏覽:112日期:2022-06-21 15:19:57
問題描述
表結構包含id,week,hot,按周切成7張表,每張表代表一周的第幾天,week代表第幾周,怎么查詢第n周hot排名前十的記錄?
問題解答
回答1:分表的分法,是要避免跨表操作。讓業務的操作在一個表中完成。如果要跨表,說明分法是不合理的。
如果真的有些業務場景要跨表,考慮多種分法同時存在,做副本冗余。
回答2:根據week的來定位到具體的表,說白了就是生成sql語句的時候指定具體的表,和mysql沒什么關系。
回答3:拼接sql語句問題,表命名要有規律,獲取當前周,拼接,前10hot用order by和top 10或limit 0,10關鍵字完成
回答4:我個人是不喜歡把邏輯放到mysql中的,所以按照你的分表方法,只能從七張表中取出每個表的top10以后,在應用程序里面再比較了。另外,我建議你按照月份水平分表,這樣能夠支持更多的業務需求。你這種分表方式更像是取模分表,天然不支持時間段內查詢與排序。
回答5:這種分表只能每張表都取前10,然后再代碼里排序,這個分表規則有問題,有這種場景的要做數據冗余
相關文章:
1. 查詢mysql數據庫中指定表指定日期的數據?有詳細2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
排行榜
