Apabila menggunakan pernyataan UPDATE MySQL untuk mengubah suai data, anda mungkin menghadapi ralat "Penggunaan UPDATE dan LIMIT yang salah ." Ralat ini timbul apabila anda cuba menggabungkan kenyataan KEMASKINI dengan sama ada klausa ORDER BY atau LIMIT dalam operasi kemas kini berbilang jadual.
Dalam coretan kod yang disediakan, pernyataan UPDATE cuba mengubah suai jadual pengguna dan jadual contact_info yang berkaitan berdasarkan syarat tertentu. Walau bagaimanapun, ia juga termasuk klausa LIMIT 1, yang tidak dibenarkan dalam senario sedemikian.
Dokumentasi MySQL secara eksplisit menyatakan bahawa untuk operasi KEMASKINI berbilang jadual, ORDER BY dan LIMIT tidak boleh digunakan. Ini kerana kenyataan KEMASKINI perlu mengemas kini semua baris yang sepadan dalam jadual yang dicantumkan dan mengehadkan kemas kini kepada bilangan baris tertentu boleh membawa kepada hasil yang tidak dijangka.
Untuk menyelesaikan ralat ini, hanya alih keluar klausa LIMIT 1 daripada kenyataan UPDATE anda. Kod yang dikemas kini akan kelihatan seperti ini:
$q = "UPDATE users INNER JOIN contact_info ON contact_info.user_id = users.user_id SET active.users = NULL WHERE (email.contact_info = '" . mysqli_real_escape_string($mysqli, $x) . "' AND active.users = '" . mysqli_real_escape_string($mysqli, $y) . "')"; $r = mysqli_query ($mysqli, $q) or trigger_error("Query: $q\n<br />MySQL Error: " . mysqli_error($mysqli));
Kod yang diubah suai ini akan melaksanakan operasi kemas kini seperti yang dimaksudkan, tanpa sebarang sekatan pada bilangan baris yang sepadan.
Atas ialah kandungan terperinci Mengapa Penyata KEMASKINI MySQL Saya Membuang \'Penggunaan UPDATE dan LIMIT yang Salah\'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!