Rumah > pangkalan data > tutorial mysql > 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
Lepaskan: 2024-10-25 09:53:02
asal
300 orang telah melayarinya

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));
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan