Soalan:
Dalam PHP, penggunaan fungsi mysql_ mempunyai telah ditamatkan dan kemudian dialih keluar. Bolehkah fungsi ini diganti secara membuta tuli dengan rakan mysqli_ mereka sepanjang projek, seperti menggantikan mysql_query() dengan mysqli_query()?
Jawapan:
Tidak, fungsi tidak boleh ditukar ganti secara langsung.
Walaupun MySQLi menyediakan fungsi yang serupa dengan mysql_, kedua-dua set fungsi adalah berbeza dari segi struktur. Hanya menggantikan mysql_ dengan mysqli_ tidak akan sentiasa berfungsi dan mungkin menimbulkan ralat.
Pendekatan Disyorkan:
Untuk memindahkan pangkalan kod anda dengan selamat, pertimbangkan langkah berikut:
1. Pelaporan Ralat:
Dayakan pelaporan ralat untuk mysqli_ untuk mengenal pasti sebarang isu yang berpotensi.
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
2. Penubuhan Sambungan:
Buat fungsi sambungan baharu yang menyimpan sambungan sebagai pembolehubah PHP, menggunakan mysqli_.
$mysqli = new mysqli($host, $username, $password, $database);
3. Pelaksanaan Pertanyaan:
Gunakan fungsi mysqli_query() dengan pembolehubah sambungan sebagai hujah pertama.
<code class="php">$result = mysqli_query($mysqli, $sql);</code>
4. Pengambilan Keputusan:
Dapatkan semula hasil menggunakan mysqli_fetch_assoc() dalam kod prosedur atau kaedah berorientasikan objek.
<code class="php">while ($row = mysqli_fetch_assoc($result)) { // ... }</code>
5. Penutupan Sambungan:
Tutup sambungan menggunakan mysqli_close() (prosedur) atau kaedah berorientasikan objek.
<code class="php">mysqli_close($mysqli); $mysqli->close();</code>
6. Penukaran Fungsi:
Tukar semua fungsi berkaitan yang bergantung pada sambungan pangkalan data atau set hasil kepada setara mysqli_ mereka.
Ingat, adalah bijak untuk menyemak dokumentasi mysqli_ untuk mendapatkan maklumat yang lebih terperinci dan untuk sahkan keserasian dengan kod khusus anda.
Atas ialah kandungan terperinci Bolehkah Fungsi MySQL Digantikan Secara Membuta tuli dengan Rakan Sejawat MySQLi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!