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

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

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

$str=‘username’;
n u m = s p r i n t f ( " num=sprintf("%u",crc32( 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查询拼接

猜你喜欢

转载自blog.csdn.net/weixin_43224306/article/details/85784403