Mysql中如何实现水平分表

83次阅读
没有评论

共计 1284 个字符,预计需要花费 4 分钟才能阅读完成。

本篇文章给大家分享的是有关 Mysql 中如何实现水平分表,丸趣 TV 小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着丸趣 TV 小编一起来看看吧。

 
1.  根据业务属性拆表
 
这种分表方式的算法大致是取模,hash,md5 等。
 
用业务属性拆表,业务关系复杂的情况下,如果要根据其他条件查询,其他的条件都必须和这个属性关联起来,查询条件必须带有这个属性。
 
例子:
 
用户 profile 表根据用户 ID 取模进行水平拆分。
 
社区里有群组,群组里有应用,应用有各种类型。可以用群组 ID,应用 ID 拆表。
 
问题:
 
根据某个条件查询时无法获取拆表的属性
 
1)  条件中含有分表的信息
 
比如用户在某网站下了订单,我们根据用户 ID 对订单进行了分表,这样用户可以方便地查询他所关联的订单。但用户投诉时,客服需要根据订单号查询订单,订单号中可以含有分表的信息,比如订单拆分成 100 张表,订单号中可以有两位用来表明该订单处于哪张表中
 
2)  用 key-value store 存储对应关联
 
原理是用 key value store 做索引表
 
3)  数据冗余
 
需要关联的表可以进行数据冗余。避免了查询。
 
例子:
 
购买礼品。购买虚拟礼品时,我们根据了购买者的 ID 进行了拆表,同时订单号中也含有了分表信息。但是用户还可能根据被赠送方进行查询,这时我们可以在购买成功后为被赠送方冗余生成一条记录。
 
4)  缓存,NOSQL
 
和数据冗余类似。例子中提到的群组应用的拆表例子,我们已经按照群组 ID 和应用类型进行了分表。但是当我要查询最近所有类型的应用时,就遇到困难了。我们需要把该群组的所有应用类型都查询一遍,而且还要再进行排序,分页等等。其实,可以用缓存的方式存储最近几百条应用。
 
2.  根据时间拆表
 
当表的关系比较复杂时,无法根据某个维度进行分表。但是有明显的时效性。
 
例子:
 
想必大家都用微薄,某人发的微薄,会被推送到千家万户。所以某条微薄是无法根据用户 ID 进行分表查询。而微薄是有很强的时效性的。一年前的默认的动态信息是不会再关心的。我们把微薄按时间分表,三个月一张表。而行级缓存(memcached)只存储了一个月。用户微薄收件箱(微薄 ID 列表)一般都是限长的。当缓存服务器重启或不命中时,需要查询 Mysql,mysql 按时间分表,缓存不命中的情况下,大部分情况下都是查近三个月的微薄。所以近 1 年的微薄我们可以存储在物理资源比较好的服务器上。
 
3.  根据自增长 ID 拆表
 
这种分割法不是取模分,而是每张表存指定量的数据。如果数据量到了,就存放到新表中。这样可以完全控制每张表的数据量。关系非常简单并且有时效性的情况下可以用。
 
4.  数据迁移的方式
 
当一些很久之前的数据,很少再查询。比如员工工资表,我们可以只存今年的工资情况。而历史数据我们可以迁移到一张 salary_old 表中, 保证数据不会丢失。但也可以用来查询。

以上就是 Mysql 中如何实现水平分表,丸趣 TV 小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计1284字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)