crc32取余校验

在分表数据库的操作中,我们经常通过crc32来进行取余来确定需要写进的表;常见的是记录用户动作的log表

例如:

$time = time();  
$tableNo = (crc32($time) % 100);  
$tableName = 'table_' . sprintf("%02d", $tableNo);
上例代表我们通过对当前时间进行对100的取余。 
但是有时我们在32位系统下进行测试的时候会出错,这是因为crc32在32位系统下可能会出现负数的情况,所以上面代码我们优化一下:

$tableNo = (crc32($time) % 100);  
if ($tableNo <= 0){  
            $tableNo = (-1) * $tableNo; // 在 32位 机器上运行会出现负数  
        }  
$tableName = 'table_' . sprintf("%02d", $tableNo);
这样就避免了服务器由32位变更为64位时出现错误。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值