Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Menetapkan Semula Penunjuk Tatasusunan Keputusan PDO untuk Berbilang Lelaran?

Bagaimana untuk Menetapkan Semula Penunjuk Tatasusunan Keputusan PDO untuk Berbilang Lelaran?

Barbara Streisand
Lepaskan: 2024-12-08 20:06:16
asal
894 orang telah melayarinya

How to Reset PDO Result Array Pointer for Multiple Iterations?

PDO: Menetapkan Semula Penunjuk Tatasusunan dalam Keputusan

Apabila berhijrah daripada kaedah MySQL SELECT ke PDO, melelaran melalui tatasusunan yang diambil dua kali dengan setiap lelaran bermula dari baris sifar menimbulkan cabaran. PDO tidak mempunyai fungsi yang setara dengan mysql_data_seek() MySQL.

Pertimbangkan menggunakan pendekatan berikut:

  1. Simpan Hasil pada Array:

    • Laksanakan pertanyaan PDO dan simpan keputusan dalam tatasusunan oleh memanggil $stmt->fetchAll().
  2. Lelaran Tatasusunan Dua Kali:

    • Lelaran melalui tatasusunan $rows dua kali, melaksanakan operasi yang diingini dalam setiap lelaran.

Berikut ialah contoh:

$pdo = new PDO('mysql:host=' . $host . ';dbname='.$database, $username, $password);
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$stmt = $pdo->prepare('SELECT * FROM mytable WHERE active = 1 ORDER BY name ASC');
$stmt->setFetchMode(PDO::FETCH_ASSOC);
$stmt->execute();

$rows = $stmt->fetchAll();

foreach ($rows as $r) {
    // first run
}

foreach ($rows as $r) {
    // second run
}
Salin selepas log masuk

Pendekatan ini secara berkesan mensimulasikan tingkah laku yang diingini untuk menetapkan semula penunjuk tatasusunan, membolehkan berbilang lelaran melalui hasil yang sama ditetapkan.

Atas ialah kandungan terperinci Bagaimana untuk Menetapkan Semula Penunjuk Tatasusunan Keputusan PDO untuk Berbilang Lelaran?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan