使用PHP更新多个字段(MySQL)

使用PHP更新多个字段(MySQL),php,mysql,Php,Mysql,我需要将数据库电话号码中的字段更新为新格式。我可以用mysql做到这一点,但鉴于mysql已经贬值,我想知道是否有人对使用mysql更新多个字段有什么建议?数字格式化程序的数字代码为: function formatPhoneNumber($phoneNumber) { $phoneNumber = preg_replace('/[^0-9]/','',$phoneNumber); if(strlen($phoneNumber) > 10) { $coun

我需要将数据库电话号码中的字段更新为新格式。我可以用mysql做到这一点,但鉴于mysql已经贬值,我想知道是否有人对使用mysql更新多个字段有什么建议?数字格式化程序的数字代码为:

function formatPhoneNumber($phoneNumber) {
    $phoneNumber = preg_replace('/[^0-9]/','',$phoneNumber);

    if(strlen($phoneNumber) > 10) {
        $countryCode = substr($phoneNumber, 0, strlen($phoneNumber)-10);
        $areaCode = substr($phoneNumber, -10, 3);
        $nextThree = substr($phoneNumber, -7, 3);
        $lastFour = substr($phoneNumber, -4, 4);

        $phoneNumber = '+'.$countryCode.' ('.$areaCode.') '.$nextThree.'-'.$lastFour;
    }
    else if(strlen($phoneNumber) == 10) {
        $areaCode = substr($phoneNumber, 0, 3);
        $nextThree = substr($phoneNumber, 3, 3);
        $lastFour = substr($phoneNumber, 6, 4);

        $phoneNumber = '('.$areaCode.') '.$nextThree.'-'.$lastFour;
    }
    else if(strlen($phoneNumber) == 7) {
        $nextThree = substr($phoneNumber, 0, 3);
        $lastFour = substr($phoneNumber, 3, 4);

        $phoneNumber = $nextThree.'-'.$lastFour;
    }

    return $phoneNumber;
}
查询将选择customers\u id,customers\u telephone,从customers\u telephone不在“”的客户中选择,将有近20000行受到影响,最有效的方法是什么

for循环看起来像这样,但它只执行阵列中的第一个客户:

foreach($customers as $row)
{
    $customer_id = $row['customers_id'];
    $numbers_array = $row['customers_telephone'];
    function formatPhoneNumber($phoneNumber) {
    $phoneNumber = preg_replace('/[^0-9]/','',$phoneNumber);

    if(strlen($phoneNumber) > 10) {
        $countryCode = substr($phoneNumber, 0, strlen($phoneNumber)-10);
        $areaCode = substr($phoneNumber, -10, 3);
        $nextThree = substr($phoneNumber, -7, 3);
        $lastFour = substr($phoneNumber, -4, 4);

        $phoneNumber = '+'.$countryCode.'-'.$areaCode.'- '.$nextThree.'-'.$lastFour;
    }
    else if(strlen($phoneNumber) == 10) {
        $areaCode = substr($phoneNumber, 0, 3);
        $nextThree = substr($phoneNumber, 3, 3);
        $lastFour = substr($phoneNumber, 6, 4);

        $phoneNumber = $areaCode.'- '.$nextThree.'-'.$lastFour;
    }
    else if(strlen($phoneNumber) == 7) {
        $nextThree = substr($phoneNumber, 0, 3);
        $lastFour = substr($phoneNumber, 3, 4);

        $phoneNumber = $nextThree.'-'.$lastFour;
    }

    return $phoneNumber;
}
    formatPhoneNumber($numbers_array);
    echo $numbers_array."  -  ".$customer_id;

}

将函数移出循环

然后更改最后两行:

$formattedNumber = formatPhoneNumber($numbers_array);
echo $formattedNumber . "  -  " . $customer_id;

我会1使用select以当前格式获取所有电话号码,并将其放入阵列中。2使用for循环,通过函数将所有数字放入新的格式数组中。3对每个条目运行更新查询。@Brobin我更新了我的原始问题,但它只执行第一行,你看到它有什么问题吗?循环中不能有该函数。您需要从循环中调用它。看看@Scott Saunders的答案。