水平分表可以提高查询的效率,但是如果订单表分了100个表,我要查询一个用户全部的订单,这样如何处理呢?
2 回答
慕运维8079593
TA贡献1876条经验 获得超5个赞
不清楚你的具体业务场景,如果你的业务场景中对用户数据的查询较多,那么分表的策略应该是和用户相关的,尽量保证每个用户的数据在同一张表中。如果是对订单ID进行的分表,并且划分了100张表的话,单纯的使用unionall是不好的,每次union的时候都要将这100张表的查询结果进行union这样操作既麻烦对mysql也不优雅。在不能修改分表策略的前提下,推荐使用MyISAMmerge引擎。对于MyISAMmerge的相关知识可以自行google。
添加回答
举报
0/150
提交
取消