Rumah  >  Artikel  >  pangkalan data  >  Mengapa Saya Mendapat Ralat \'Arahan tidak segerak\' Apabila Menggunakan Berbilang Penyata PHP MySQLi Disediakan?

Mengapa Saya Mendapat Ralat \'Arahan tidak segerak\' Apabila Menggunakan Berbilang Penyata PHP MySQLi Disediakan?

Patricia Arquette
Patricia Arquetteasal
2024-11-21 07:32:11605semak imbas

Why Do I Get

Arahan PHP Tidak Segerak: Menyelesaikan Ralat dalam Penggunaan Berbilang Penyata Disediakan

Dalam PHP, apabila cuba melaksanakan berbilang pernyataan yang disediakan menggunakan MySQLi , anda mungkin menghadapi ralat "Perintah tidak segerak, anda tidak boleh menjalankan perintah itu sekarang." Ralat ini berlaku disebabkan oleh pengendalian lalai MySQLi bagi set hasil daripada pertanyaan.

Satu potensi punca ralat ini ialah penggunaan MYSQLI_USE_RESULT semasa melaksanakan pertanyaan. Mod ini mengoptimumkan prestasi dengan mengelakkan penimbalan bagi keseluruhan set hasil. Walau bagaimanapun, ia memerlukan anda mengeluarkan hasil secara manual menggunakan mysqli_free_result(). Jika anda gagal berbuat demikian sebelum melaksanakan pernyataan berikutnya, urutan perintah menjadi tidak segerak.

Untuk menyelesaikan isu ini, pastikan anda memanggil mysqli_free_result() selepas mengambil semua baris daripada setiap pernyataan. Sebagai alternatif, anda boleh menggunakan kaedah store_result() untuk menyimpan keseluruhan set hasil dalam memori, membolehkan anda mengaksesnya kemudian tanpa perlu risau tentang kemungkinan konflik.

Satu lagi punca biasa ralat ini ialah kehadiran keputusan yang belum selesai daripada pertanyaan sebelumnya. Apabila melaksanakan berbilang pertanyaan dalam satu gelung, pastikan anda memanggil mysqli_next_result() selepas memproses setiap set hasil. Kaedah ini mengeluarkan sebarang hasil yang tinggal dan menyediakan sambungan untuk pertanyaan seterusnya.

Berikut ialah contoh cara membetulkan ralat dengan memanggil kedua-dua mysqli_free_result() dan mysqli_next_result():

$stmt = $mysqli->prepare("SELECT id, username, password, firstname, lastname, salt FROM members WHERE email = ? LIMIT 1");
$stmt->bind_param('s', $loweredEmail);
$stmt->execute();
$stmt->store_result();
$stmt->bind_result($user_id, $username, $db_password, $firstname, $lastname, $salt);
$stmt->fetch();

$stmt->free_result();
$stmt->close();

while ($mysqli->more_results()) {
    $mysqli->next_result();
}

$stmt1 = $mysqli->prepare("SELECT privileges FROM delegations WHERE id = ? LIMIT 1");
$stmt1->bind_param('s', $user_id);
$stmt1->execute();
$stmt1->store_result();
$stmt1->bind_result($privileges);
$stmt1->fetch();

Oleh mengendalikan set hasil dengan betul dan melepaskannya apabila tidak diperlukan, anda boleh mengelakkan ralat "Arahan tidak segerak" dan memastikan pelaksanaan lancar berbilang pernyataan yang disediakan.

Atas ialah kandungan terperinci Mengapa Saya Mendapat Ralat \'Arahan tidak segerak\' Apabila Menggunakan Berbilang Penyata PHP MySQLi Disediakan?. 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