在分表数据库的操作中,我们经常通过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位时出现错误。