Mengulang melalui Keputusan MySQLi: Panduan Komprehensif
Apabila bekerja dengan pangkalan data MySQL menggunakan PHP dan MySQLi, gelung yang cekap melalui set hasil adalah penting. Panduan ini menangani isu biasa pengambilan data daripada hasil pertanyaan dan mengkaji kemungkinan perangkap dan penyelesaian yang terlibat.
Masalah: Hanya Mengambil Nilai Pertama
Pertimbangkan perkara berikut pertanyaan dan kod PHP bertujuan untuk mengulangi hasil:
select uid from userbase
<?php $output = mysqli_query($mysqli, "select uid from userbase"); while ($row = $output->fetch_array()) { $deviceToken = $row[0]; echo $deviceToken; } ?>
Kod ini direka bentuk untuk mencetak semua nilai 'uid' dalam set hasil. Walau bagaimanapun, ia hanya mengambil nilai pertama. Punca isu ini terletak pada penggunaan 'fetch_array()'.
'fetch_array()': Gelagat Lalai dan Alternatif
Secara lalai, 'fetch_array( )' mengembalikan kedua-dua elemen diindeks dan bersekutu dalam tatasusunan keputusannya (MYSQLI_BOTH). Untuk mendapatkan semula data yang diindeks atau bersekutu secara khusus, gunakan MYSQLI_NUM atau MYSQLI_ASSOC, masing-masing, seperti berikut:
while ($row = $output->fetch_array(MYSQLI_ASSOC)) { echo $row['uid']; }
while ($row = $output->fetch_array(MYSQLI_NUM)) { echo $row[0]; }
Lelaran Berorientasikan Objek: Pendekatan Lebih Ringkas
Pendekatan yang lebih cekap dan ringkas untuk lelaran melalui keputusan MySQLi adalah dengan menggunakan sifat boleh lelarannya. Kaedah query() boleh digunakan sebagai objek boleh lelar, menghapuskan keperluan untuk 'fetch_array()'.foreach ($output as $row) { echo $row['uid']; }
Awas: Percanggahan Pengindeksan Tatasusunan
Ia penting untuk ambil perhatian bahawa pembolehubah $i meningkat dengan setiap lelaran baris walaupun kekurangan elemen sepadan dalam tatasusunan hasil. Percanggahan ini berpunca daripada penjajaran pengindeksan, mengakibatkan ralat indeks yang tidak ditentukan semasa lelaran berikutnya.Kesimpulan
Memahami kehalusan lelaran hasil MySQLi adalah penting untuk pengendalian data yang berkesan. Menggunakan pendekatan berorientasikan objek dan sifat hasil pertanyaan yang boleh diulang boleh memudahkan proses ini, membawa kepada operasi pangkalan data yang lebih cekap dan tepat.Atas ialah kandungan terperinci Cara Mengulangi Dengan Betul Melalui Keputusan MySQLi: Mengelakkan Perangkap Biasa dan Memilih Pendekatan Terbaik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!