Rumah >pangkalan data >tutorial mysql >`bind_result` lwn. `get_result`: Kaedah MySQLi Yang Mana Perlu Saya Gunakan untuk Mendapatkan Keputusan Pertanyaan?

`bind_result` lwn. `get_result`: Kaedah MySQLi Yang Mana Perlu Saya Gunakan untuk Mendapatkan Keputusan Pertanyaan?

Susan Sarandon
Susan Sarandonasal
2024-12-13 03:28:10682semak imbas

`bind_result` vs. `get_result`: Which MySQLi Method Should I Use for Retrieving Query Results?

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:

  • Serasi dengan versi PHP lapuk
  • Mengembalikan berasingan pembolehubah

Keburukan bind_result:

  • Penyenaraian manual semua pembolehubah yang diperlukan
  • Memerlukan lebih banyak kod untuk mengembalikan baris sebagai tatasusunan
  • Kod mesti dikemas kini apabila struktur jadual perubahan

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:

  • Returns associative/ tatasusunan terhitung atau objek diisi secara automatik dengan data
  • Membenarkan kaedah fetch_all() untuk kembalikan semua baris yang dikembalikan sekali gus

Keburukan get_result:

  • Memerlukan pemacu asli MySQL (mysqlnd)

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!

Kenyataan:
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