Какой самый эффективный способ переписать эту функцию? - PullRequest
1 голос
/ 16 января 2009
    function get_total_adults()
{
    $sql = "SELECT SUM(number_adults_attending) as number_of_adults FROM is_nfo_rsvp";
    $result = mysql_query($sql) or die(mysql_error());
    $array = mysql_fetch_assoc($result);

    return $array['number_of_adults'];
}

Я знаю, что есть способ написать это с меньшим количеством кода. Я просто ищу лучший способ (без использования чего-то вроде ezSQL).

Ответы [ 3 ]

1 голос
/ 16 января 2009
function get_total_adults() {
    $sql = 'SELECT SUM(number_adults_attending) FROM is_nfo_rsvp';
    $result = mysql_query($sql) or die(mysql_error());
    // I'd throw a catchable exception (see below) rather than die with a MySQl error

    return mysql_result($result, 0);
}

Что касается того, как я предпочитаю обрабатывать ошибки:

function get_total_adults() {
    $sql = 'SELECT SUM(number_adults_attending) FROM is_nfo_rsvp';
    $result = mysql_query($sql);
    if (!$result) {
        throw new Exception('Failed to get total number of adults attending');
    }

    return mysql_result($result, 0);
}

try {
    $total_adults = get_total_adults();
} catch(Exception $ex) {
    die('Whoops! An error occurred: ' . $ex->getMessage());
    // or even better, add to your template and dump the template at this point
}
// continue code
0 голосов
/ 16 января 2009

Вы также можете попробовать refactormycode.com

0 голосов
/ 16 января 2009

Вы можете удалить часть запроса "as number_of_adults" и использовать mysql_result.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...