码迷,mamicode.com
首页 > 数据库 > 详细

MySQL如何实现分库分表,如何提高查询效率

时间:2019-07-14 15:05:29      阅读:115      评论:0      收藏:0      [点我收藏+]

标签:rom   handle   更改   水平   mysql   hand   方案   字段   效率   

本人没有做过电商平台,但了解其中的道道,今天闲来无事,说说其中的道道。下边我要开始表演了。

在大型电商网站中,随着业务的增多,数据库中的数据量也是与日俱增,这时候就要将数据库进行分库分表了。

技术图片

 

1、如何分库分表?

两种解决方案:垂直拆分、水平拆分

垂直拆分:根据业务进行拆分,比如可以将一张表中的多个字段拆成两张表,一张是不经常更改的,一张是经常改的。

水平拆分:即根据表来进行分割:比如user表可以拆分为user0,、user1、user2、user3、user4等

2、分库分表之后如何实现联合查询?

可以使用第三方中间件来实现,比如:mycat、shading-jdbc

原理解析:

当客户端发送一条sql查询:select * from user;此时中间件会根据有几个子表,拆分成多个语句:select * from user1;select * from user2;select * from user3等多条语句查询,然后将查询的结果返回给中间件,然后汇总给客户端。这些语句是并发执行的,所以效率会很高哦。

MySQL如何实现分库分表,如何提高查询效率

标签:rom   handle   更改   水平   mysql   hand   方案   字段   效率   

原文地址:https://www.cnblogs.com/mengtaoadmin/p/11184047.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!