ホームページ >バックエンド開発 >PHPチュートリアル >MySQL プリペアド ステートメントは複数のクエリを一度に処理できますか?

MySQL プリペアド ステートメントは複数のクエリを一度に処理できますか?

Barbara Streisand
Barbara Streisandオリジナル
2024-11-21 11:22:10692ブラウズ

Can MySQL Prepared Statements Handle Multiple Queries at Once?

単一の mysqli ステートメントで複数のクエリを準備できますか?

MySQL では、準備されたステートメントは単一のクエリのみを実行します。 1 つのステートメントで複数のクエリを準備することはできませんが、クエリごとに個別のプリペアド ステートメントを作成できます。

次の例を考えてみましょう。

$stmtUser = $sql->prepare("INSERT INTO user (id_user, username, pw, email) VALUES (?,?,?,?)");
$stmtProc = $sql->prepare("INSERT INTO process (id_user, idp) VALUES (?,?);");

ここでは、2 つのプリペアド ステートメント ($ stmtUser と $stmtProc) が作成されました。その後、必要に応じてこれらのステートメントを実行できます。

$stmtUser->execute();
$stmtProc->execute();

両方のクエリを確実に一緒に実行する必要がある場合は、トランザクションを使用してそれらをグループ化できます。トランザクションは、両方のクエリが実行されるか、どちらも実行されないことを保証します。

ヒント: 「非オブジェクトのメンバー関数の呼び出し」エラーは、多くの場合、prepare() が失敗したことを示します。問題を解決するには、prepare() のクエリを確認してください。

以上がMySQL プリペアド ステートメントは複数のクエリを一度に処理できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。