1、假如说我们目前已有一亿个注册用户,要把这些用户平均分配到100张表中,并且后续注册的用户也要均匀分配到这100张表
首先当用户注册时,如用户名为“username”,用php的crc32()函数处理用户名,得到一个数值4166911607,代码如下
$str=‘username’;
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查询拼接