Rumah  >  Artikel  >  pangkalan data  >  Mengapa Penyata KEMASKINI MySQL Saya Membuang \"Penggunaan UPDATE dan LIMIT yang Salah\"?

Mengapa Penyata KEMASKINI MySQL Saya Membuang \"Penggunaan UPDATE dan LIMIT yang Salah\"?

Barbara Streisand
Barbara Streisandasal
2024-10-25 09:53:02188semak imbas

Why Does My MySQL UPDATE Statement Throw

Memahami Ralat MySQL: Penggunaan UPDATE dan LIMIT yang Salah

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.

Konteks:

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.

Penyelesaian:

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!

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