PHP/mysqli を使用した MySQL のストアド プロシージャからの複数の結果セットの処理
PHP/mysqli のストアド プロシージャから複数の結果セットを取得するには、 mysqli_stmt_next_result() 関数を使用して実現します。次の例は、この関数を使用して 2 番目の結果セットに進む方法を示しています。
<code class="php">$stmt = mysqli_prepare($db, 'CALL multiples(?, ?)'); mysqli_stmt_bind_param($stmt, 'ii', $param1, $param2); mysqli_stmt_execute($stmt); // Fetch and process the first result set $result1 = mysqli_stmt_get_result($stmt); while ($row1 = mysqli_fetch_assoc($result1)) { // Process row1 } // Advance to the second result set mysqli_stmt_next_result($stmt); if (mysqli_stmt_error($stmt)) { die('Failed to advance to the second result set: ' . mysqli_stmt_error($stmt)); } // Fetch and process the second result set $result2 = mysqli_stmt_get_result($stmt); while ($row2 = mysqli_fetch_assoc($result2)) { // Process row2 }</code>
PDO Solution
PDO を使用すると、コードは次のようになります。
<code class="php">$stmt = $db->prepare('CALL multiples(:param1, :param2)'); $stmt->execute([':param1' => $param1, ':param2' => $param2]); // Fetch and process the first result set while ($row1 = $stmt->fetch()) { // Process row1 } // Advance to the second result set $stmt->nextRowset(); // Fetch and process the second result set while ($row2 = $stmt->fetch()) { // Process row2 }</code>
注:
すべてのデータベース サーバーがストアド プロシージャからの複数の結果セットをサポートしているわけではないことに注意することが重要です。互換性については、データベース サーバーのドキュメントを必ず参照してください。
以上がPHP/mysqli および PDO を使用して MySQL のストアド プロシージャから複数の結果セットを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。