mysql 关于分表后查询问题

2018-02-06 14:11:06 +08:00
 leonidas
例如:
现有订单表共 5 千万数据 根据订单生成时间分为了 5 张表 每张 1 千万
tab_order_1,tab_order_2,tab_order_3,tab_order_4,tab_order_5

现在我要查询所有订单金额大于 10 的该怎么查呢?
表引擎为 innodb

有什么好的方法吗? 貌似类似的问题经常面试会遇到。
merge 的话就算了 因为 merge 要用 myisam 而 myisam 不支持事务 那样就没意义了。
union 的话的确是可以 但这样的话 分表是不是就没有任何意义了。

-----------------------------------------------------------------------------------------------------------------------------------------------

这里说的“查询所有订单金额大于 10 “ 只是举个例子,现实中查询条件可能会更为苛刻,如会加上状态啊等等
4129 次点击
所在节点    程序员
6 条回复
Rickkkkkkk
2018-02-06 14:13:31 +08:00
这种查询用 es
woodface2233
2018-02-06 17:00:05 +08:00
分表之后还在业务库全表查询?不带分表条件?
oneonesv
2018-02-06 17:06:52 +08:00
分表总的有个条件吧 根据分表的条件定位具体那个表
gewenrui00
2018-02-06 17:08:15 +08:00
es
linpf
2018-02-07 10:40:45 +08:00
这就要根据具体业务进行分表设计了。
一般来说,分表都是根据最高频查询的字段进行拆分的。但是考虑到很多功能是需要全局查询,所以在这种情况下,是无法避免全局查询的。
对于经常需要全局查询的部分数据,可以单独做个冗余表,这部分就不要分表了。
对于不经常的全局查询,就只能 union 了。但是通常情况下这种查询响应时间都很久。所以就需要在功能上做一定的限制。比如查询间隔之类的,防止数据库长时间无响应。或者把数据同步到只读从库上,在从库上进行搜索。不影响主库运行。
leonidas
2018-02-07 11:56:12 +08:00
@woodface2233 @zxyawx @linpf
嗯 这里我是举了个例子 根据订单生成时间来分表 我想 5 楼解答了我的疑惑
经常面试时会碰到类似的问题

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/428896

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX