对用户表分表,使用户均匀分布

1、假如说我们目前已有一亿个注册用户,要把这些用户平均分配到100张表中,并且后续注册的用户也要均匀分配到这100张表

首先当用户注册时,如用户名为“username”,用php的crc32()函数处理用户名,得到一个数值4166911607,代码如下

$str=‘username’;
n u m = s p r i n t f ( " num=sprintf("%u",crc32( num=sprintf("str));

注意:由于 PHP 的整数是带符号的,所以在 32 位系统上许多 crc32 校验码将返回负整数。 尽管在 64 位上所有 crc32() 的结果将都是正整数。因此你需要使用 sprintf()的“%u”格式符来获取表示无符号 crc32 校验码的字符串。

然后,我用得到近个数值变量求模,$num%100=47,因此我们把’username’添加到第47个表中。

同样的,当用户登录时我们就可以通过同样的方法去第47个表中查找用户名为’username’的数据

2、在开发中,整型的数值可以通过取模(mod)来进行分表,但是,对于帐号这种字符串类型,却不能实现。

怎么办呢,我们可以通过CRC32这个函数来分表,函数如下:

function account_hash($account,$tail=4,$mod=1)
{
	$crc32=sprintf("%u",crc32($account));//使用%u解决32位下出现负数的问题
	return fmod(substr(strval($crc32),-$tail,$tail),$mod);	//取模计算数值
}

用这个函数,可以灵活定义分表的离散程度和分表数量

3、按照相同方法进行分库操作对某一个小的数字取模确定在那个库里

4、分表之后用户名唯一验证,暂时用UNION查询拼接

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值