文章詳情頁
mysql分表之后怎么查詢
瀏覽:106日期:2022-06-21 15:19:57
問題描述
表結(jié)構(gòu)包含id,week,hot,按周切成7張表,每張表代表一周的第幾天,week代表第幾周,怎么查詢第n周hot排名前十的記錄?
問題解答
回答1:分表的分法,是要避免跨表操作。讓業(yè)務(wù)的操作在一個(gè)表中完成。如果要跨表,說明分法是不合理的。
如果真的有些業(yè)務(wù)場(chǎng)景要跨表,考慮多種分法同時(shí)存在,做副本冗余。
回答2:根據(jù)week的來定位到具體的表,說白了就是生成sql語句的時(shí)候指定具體的表,和mysql沒什么關(guān)系。
回答3:拼接sql語句問題,表命名要有規(guī)律,獲取當(dāng)前周,拼接,前10hot用order by和top 10或limit 0,10關(guān)鍵字完成
回答4:我個(gè)人是不喜歡把邏輯放到mysql中的,所以按照你的分表方法,只能從七張表中取出每個(gè)表的top10以后,在應(yīng)用程序里面再比較了。另外,我建議你按照月份水平分表,這樣能夠支持更多的業(yè)務(wù)需求。你這種分表方式更像是取模分表,天然不支持時(shí)間段內(nèi)查詢與排序。
回答5:這種分表只能每張表都取前10,然后再代碼里排序,這個(gè)分表規(guī)則有問題,有這種場(chǎng)景的要做數(shù)據(jù)冗余
相關(guān)文章:
1. docker-compose 為何找不到配置文件?2. boot2docker無法啟動(dòng)3. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?4. java中返回一個(gè)對(duì)象,和輸出對(duì)像的值,意義在哪兒5. android - E/dalvikvm: Could not find class java.nio.file.Path,6. python - linux怎么在每天的凌晨2點(diǎn)執(zhí)行一次這個(gè)log.py文件7. android - 哪位大神知道java后臺(tái)的api接口的對(duì)象傳到前端后輸入日期報(bào)錯(cuò),是什么情況?求大神指點(diǎn)8. mysql數(shù)據(jù)庫(kù)每次查詢是一條線程嗎?9. python是怎么實(shí)現(xiàn)過濾 #注釋代碼的?10. 請(qǐng)問一下各位老鳥 我一直在學(xué)習(xí)獨(dú)孤九賤 現(xiàn)在是在tp5 今天發(fā)現(xiàn) 這個(gè)系列視頻沒有實(shí)戰(zhàn)
排行榜

熱門標(biāo)簽