Php / mysqli'nin saklanan prosedür ile birden çok sonuç kümesi alınıyor

2 Cevap php

Ben birden çok sonuç kümesi olan bir saklı yordam var. Nasıl bu sonuçları elde etmek için mysqli'nin belirlenen 2 sonucu ilerlemek mi?

Kullanıcının bu gibi bir saklı yordam diyelim:

create procedure multiples( param1 INT, param2 INT )
BEGIN

SELECT * FROM table1 WHERE id = param1;

SELECT * FROM table2 WHERE id = param2;

END $$

PHP bu gibi bir şeydir:

$stmt = mysqli_prepare($db, 'CALL multiples(?, ?)');

mysqli_stmt_bind_param( $stmt, 'ii', $param1, $param2 );

mysqli_stmt_execute( $stmt );

mysqli_stmt_bind_result( $stmt, $id );

Sonra bu işe alınamıyor parçasıdır. Ben sonraki sonuç kümesine gitmek için mysqli_next_result kullanarak denedim, ancak çalışması için alınamıyor. Biz mysqli_store_result ve mysqli_fetch_assoc / dizi / satır ile çalışmak için yaptım, ama nedense tüm ints boş dizeleri olarak döndü olsun.

Herhangi bir kimse bu rastlamak ve bir çözüm var mı?

2 Cevap

Ben (şu test edilmemiştir) burada bir şey eksik düşünüyorum:

$stmt = mysqli_prepare($db, 'CALL multiples(?, ?)');
mysqli_stmt_bind_param($stmt, 'ii', $param1, $param2);
mysqli_stmt_execute($stmt);
// fetch the first result set
$result1 = mysqli_use_result($db);
// you have to read the result set here 
while ($row = $result1->fetch_assoc()) {
    printf("%d\n", $row['id']);
}
// now we're at the end of our first result set.
mysqli_free_result($result1);

//move to next result set
mysqli_next_result($db);
$result2 = mysqli_use_result($db);
// you have to read the result set here 
while ($row = $result2->fetch_assoc()) {
    printf("%d\n", $row['id']);
}
// now we're at the end of our second result set.
mysqli_free_result($result2);

// close statement
mysqli_stmt_close($stmt);

Kullanımı PDO kodu gibi görünecektir:

$stmt = $db->prepare('CALL multiples(:param1, :param2)');
$stmt->execute(array(':param1' => $param1, ':param2' => $param2));
// read first result set
while ($row = $stmt->fetch()) {
    printf("%d\n", $row['id']);
}
$stmt->nextRowset();
// read second result set
while ($row = $stmt->fetch()) {
    printf("%d\n", $row['id']);
}

Ama ben PDOStatement::nextRowset() is not implemented with the MySQL PDO driver imkansız birden çok sonuç kümelerini almak için yapma duydum:

Yani, PHP sürümüne bağlı olarak, sopa olurdu sizin mysqli -solution. By the way: do you use the procedural style deliberately? Using object oriented style with mysqli kod biraz daha çekici (benim kişisel görüşüm) görünmesini istiyorsunuz.

MySQLi_STMT nesneler farklı MySQLi_Result nesnelerden çalışmak beri MySQLi sadece, mysqli_multi_query() ile birden çok sonuç kümesi destek olabilir gibi görünüyor.

PDO PDOStatement nesneler düzenli sorguları (PDO::query) ve hazırlanan tabloların her ikisi için birden çok sonuç kümeleri idare edememek, biraz daha soyutlanmış gibi görünüyor (PDO:prepare) .