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

 我来答
懂视生活
2023-07-27 · 百度认证:湖南福仁科技有限公司官方账号
懂视生活
向TA提问
展开全部


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

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



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如何实现分库分表,如何提高查询效率
标签:romhandle更改水平mysqlhand方案字段效率

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式