码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-09-08 18:55:45      阅读:250      评论:0      收藏:0      [点我收藏+]

标签:name   校验码   crc   sha   获取   结果   www.   用户注册   返回   

假如说我们目前已有一亿个注册用户,要把这些用户平均分配到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‘的数据

 

 

 

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

标签:name   校验码   crc   sha   获取   结果   www.   用户注册   返回   

原文地址:https://www.cnblogs.com/goufugui/p/9609941.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!