Memilih Antara bind_result dan get_result
Apabila bekerja dengan pernyataan yang disediakan untuk pertanyaan pangkalan data, memilih kaedah yang sesuai untuk mengendalikan hasilnya boleh memberi kesan yang ketara kepada kecekapan dan fleksibiliti kod anda. Artikel ini mengkaji perbezaan antara bind_result dan get_result, dua kaedah yang biasa digunakan untuk mendapatkan semula data hasil.
bind_result
bind_result sesuai apabila kawalan tepat ke atas pembolehubah tugasan diingini. Dengan menyatakan secara eksplisit pembolehubah yang akan diikat pada setiap lajur, ia memastikan susunan pembolehubah sepadan dengan struktur baris yang dikembalikan. Pendekatan ini berfaedah apabila struktur baris yang dikembalikan diketahui lebih awal dan kod itu boleh disesuaikan dengan sewajarnya.
$query1 = 'SELECT id, first_name, last_name, username FROM `table` WHERE id = ?'; $id = 5; $stmt = $mysqli->prepare($query1); /* Binds variables to prepared statement i corresponding variable has type integer d corresponding variable has type double s corresponding variable has type string b corresponding variable is a blob and will be sent in packets */ $stmt->bind_param('i',$id); /* execute query */ $stmt->execute(); /* Store the result (to get properties) */ $stmt->store_result(); /* Get the number of rows */ $num_of_rows = $stmt->num_rows; /* Bind the result to variables */ $stmt->bind_result($id, $first_name, $last_name, $username); while ($stmt->fetch()) { echo 'ID: '.$id.'<br>'; echo 'First Name: '.$first_name.'<br>'; echo 'Last Name: '.$last_name.'<br>'; echo 'Username: '.$username.'<br><br>'; }
Kebaikan bind_result:
Keburukan bind_result:
get_result
get_result menyediakan penyelesaian yang lebih serba boleh untuk pengambilan data. Ia secara automatik mencipta tatasusunan bersekutu/dikira atau objek yang mengandungi data daripada baris yang dikembalikan. Kaedah ini mudah apabila berurusan dengan struktur hasil dinamik atau apabila fleksibiliti dalam mengakses data adalah penting.
$query2 = 'SELECT * FROM `table` WHERE id = ?'; $id = 5; $stmt = $mysqli->prepare($query2); /* Binds variables to prepared statement i corresponding variable has type integer d corresponding variable has type double s corresponding variable has type string b corresponding variable is a blob and will be sent in packets */ $stmt->bind_param('i',$id); /* execute query */ $stmt->execute(); /* Get the result */ $result = $stmt->get_result(); /* Get the number of rows */ $num_of_rows = $result->num_rows; while ($row = $result->fetch_assoc()) { echo 'ID: '.$row['id'].'<br>'; echo 'First Name: '.$row['first_name'].'<br>'; echo 'Last Name: '.$row['last_name'].'<br>'; echo 'Username: '.$row['username'].'<br><br>'; }
Kebaikan get_result:
Keburukan get_result:
Kesimpulan
Pilihan antara bind_result dan get_result bergantung pada keperluan khusus aplikasi. bind_result menyediakan ketepatan dan kawalan ke atas data hasil, tetapi boleh menyusahkan untuk struktur data dinamik. get_result menawarkan fleksibiliti dan kemudahan, tetapi mungkin tidak disokong dalam versi PHP yang lebih lama. Memahami kelebihan dan had setiap kaedah membolehkan pembangun membuat keputusan termaklum semasa mengendalikan hasil pertanyaan.
Atas ialah kandungan terperinci `bind_result` lwn. `get_result`: Kaedah MySQLi Yang Mana Perlu Saya Gunakan untuk Mendapatkan Keputusan Pertanyaan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!