単一の 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 サイトの他の関連記事を参照してください。