文章详情页
mysql分表之后怎么查询
浏览:207日期: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. javascript - ios返回不执行js怎么解决?2. MYSQL 根据两个字段值查询 但两个值的位置可能是互换的,这个怎么查?3. css - 有没有什么办法用背景色把部分border给遮挡呢?4. delete关键字删除元素的时候,它的值是默认为什么类型呢?可以默认是为0嘛?5. java for循环的时候增加循环体的长度是不是不太好的?6. 通过AJP的Tomcat 7 Websockects无法正常工作有什么建议么?7. mysql - 千万级数据表如何有效的变更字段?8. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????9. docker gitlab 如何git clone?10. css3 - canvas在IOS8中不兼容。画不出来。
排行榜

网公网安备