ホームページ  >  記事  >  バックエンド開発  >  PHP/mysqli および PDO を使用して MySQL のストアド プロシージャから複数の結果セットを取得する方法

PHP/mysqli および PDO を使用して MySQL のストアド プロシージャから複数の結果セットを取得する方法

DDD
DDDオリジナル
2024-10-30 19:30:02734ブラウズ

How to Retrieve Multiple Result Sets from Stored Procedures in MySQL with PHP/mysqli and PDO?

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

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