php+MySQL的对用户表分表,使用户均匀分布

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

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

<?php
$str='username';
$num=sprintf("%u",crc32($str));

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

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

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

 

 

 

posted @ 2018-09-08 18:09  苟富贵,无相忘  阅读(1179)  评论(0编辑  收藏  举报