欢迎来到装配图网! | 帮助中心 装配图网zhuangpeitu.com!
装配图网
ImageVerifierCode 换一换
首页 装配图网 > 资源分类 > DOCX文档下载
 

数据库水平切分方法

  • 资源ID:193438244       资源大小:10.08KB        全文页数:3页
  • 资源格式: DOCX        下载积分:12积分
快捷下载 游客一键下载
会员登录下载
微信登录下载
三方登录下载: 微信开放平台登录 支付宝登录   QQ登录   微博登录  
二维码
微信扫一扫登录
下载资源需要12积分
邮箱/手机:
温馨提示:
用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
支付方式: 支付宝    微信支付   
验证码:   换一换

 
账号:
密码:
验证码:   换一换
  忘记密码?
    
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

数据库水平切分方法

在大中型项目中,在数据库设计的时候,考虑到数据库最大承受数据量,通常会把数据库或 者数据表水平切分,以降低单个库,单个表的压力。我这里介绍两个我们项目中常用的数据 表切分方法。当然这些方法都是在程序中使用一定的技巧来路由到具体的表的。首先我们要 确认根据什么来水平切分?在我们的系统(SNS)中,用户的UID贯穿系统,唯一自增长, 根据这个字段分表,再好不过。方法一:使用MD5哈希做法是对UID进行md5加密,然后取前几位(我们这里取前两位),然后就可以将 不同的UID哈希到不同的用户表(user_xx)中了。function getTable( $uid )$ext = substr ( md5 ($uid) ,0 ,2 );return "user_".$ext;通过这个技巧,我们可以将不同的UID分散到256中用户表中,分别是 user_00,user_01 user_ff。因为UID是数字且递增,根据md5的算法,可以将用户数据几乎很均匀的分别到不同的user表中。但是这里有个问题是,如果我们的系统的用户越来越多,势必单张表的数据量越来越大, 而且根据这种算法无法扩展表,这又会回到文章开头出现的问题了。方法二:使用移位具体方法是:public function getTable( $uid ) return "user_" . sprintf ( "%04d", ($uid >> 20);这里,我们将uid向右移动20位,这样我们就可以把大约前100万的用户数据放在 第一个表user_0000,第二个100万的用户数据放在第二个表user_0001中,这样一直 下去,如果我们的用户越来越多,直接添加用户表就行了。由于我们保留的表后缀是四位, 这里我们可以添加1万张用户表,即user_0000,user_0001 user_9999。一万张 表,每张表100万数据,我们可以存100亿条用户记录。当然,如果你的用户数据比这还 多,也不要紧,你只要改变保留表后缀来增加可以扩展的表就行了,如如果有1000亿条数 据,每个表存100万,那么你需要10万张表,我们只要保留表后缀为6位即可。上面的算法还可以写的灵活点:/*根据UID分表算法I* param int $uid /用户 ID* param int $bit/表后缀保留几位* param int $seed /向右移动位数*/function getTable( $uid , $bit , $seed )return "user_" . sprintf ( "%0$bitd" , ($uid >> $seed);总结:上面两种方法,都要对我们当前系统的用户数据量做出可能最大的预估,并且对数据库 单个表的最大承受量做出预估。比如第二种方案,如果我们预估我们系统的用户是100亿,单张表的最优数据量是100 万,那么我们就需要将UID移动20来确保每个表是100万的数据,保留用户表(user_xxxx) 四位来扩展1万张表。又如第一种方案,每张表100万,md5后取前两位,就只能有256张表了,系统总 数据库就是:256*100万;如果你系统的总数据量的比这还多,那你实现肯定要MD5取 前三位或者四位甚至更多位了。两种方法都是将数据水平切分到不同的表中,相对第一种方法,第二种方法更具扩展 性。

注意事项

本文(数据库水平切分方法)为本站会员(ba****u)主动上传,装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知装配图网(点击联系客服),我们立即给予删除!

温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!