ホームページ > データベース > mysql チュートリアル > PHP で複数の MySQL クエリを効率的に実行するにはどうすればよいですか?

PHP で複数の MySQL クエリを効率的に実行するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-06 07:13:11
オリジナル
611 人が閲覧しました

How to Execute Multiple MySQL Queries Efficiently in PHP?

PHP での MySQL の複数のクエリ

複雑なデータベース操作を扱う場合、単一の PHP スクリプトで複数のクエリを実行することが必要になる場合があります。 PHP と MySQL を使用してこれを実現する方法は次のとおりです。

あなたの場合、複数のクエリを 1 つの結果にマージしようとしたときにエラーが発生しました。これを解決するための重要な解決策は、mysqli_multi_query() 関数を利用することです。クエリを連結してこの関数に渡すことで、それらを順番に実行できます。

mysqli_multi_query() を使用したコードの改訂版は次のとおりです。

$link = mysqli_connect("server", "user", "password", "database");

$query = "CREATE VIEW current_rankings AS SELECT * FROM main_table WHERE date = X;";
$query .= "CREATE VIEW previous_rankings AS SELECT rank FROM main_table WHERE date = date_sub('X', INTERVAL 1 MONTH);";
$query .= "CREATE VIEW final_output AS SELECT current_rankings.player, current_rankings.rank AS current_rank, previous_rankings.rank AS prev_rank FROM current_rankings LEFT JOIN previous_rankings ON (current_rankings.player = previous_rankings.player);";
$query .= "SELECT *, @rank_change = prev_rank - current_rank AS rank_change FROM final_output;";

if (mysqli_multi_query($link, $query)) {
    do {
        if ($result = mysqli_store_result($link)) {
            while ($row = mysqli_fetch_array($result)) {
                echo $row['player'] . ' ' . $row['current_rank'] . ' ' . $row['prev_rank'] . ' ' . $row['rank_change'] . '<br>';
            }
            mysqli_free_result($result);
        }
    } while (mysqli_next_result($link));
}
ログイン後にコピー

「X」を忘れずに置き換えてください。クエリ内で適切な日付パラメータを使用します。

代替アプローチ

クエリを順番に実行するだけで十分な場合は、複数の mysqli_query() 呼び出しを使用して各クエリを個別に実行できます。例:

$query1 = "Create temporary table A select c1 from t1;";
mysqli_query($link, $query1) or die(mysqli_error());

$query2 = "select c1 from A;";
$result2 = mysqli_query($link, $query2) or die(mysqli_error());

while ($row = mysqli_fetch_array($result2)) {
    echo $row['c1'];
}
ログイン後にコピー

以上がPHP で複数の MySQL クエリを効率的に実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート