Menggunakan klausa WHERE dalam pernyataan MySQL INSERT mengakibatkan ralat. Ini kerana klausa WHERE direka khusus untuk operasi KEMASKINI dan PADAM, bukan INSERT.
Pertanyaan yang disediakan mungkin bertujuan untuk sama ada menambah pengguna baharu atau mengubah suai pengguna sedia ada. Mari kita jelaskan kedua-dua senario:
Untuk memasukkan pengguna baharu dengan ID 1, sintaks MySQL yang betul ialah:
<code class="language-sql">INSERT INTO Users (id, weight, desiredWeight) VALUES (1, 160, 145);</code>
Ini memberikan nilai secara langsung kepada id
, weight
dan desiredWeight
, mencipta rekod pengguna baharu.
Jika matlamatnya adalah untuk mengemas kini pengguna sedia ada, gunakan kenyataan KEMASKINI:
<code class="language-sql">UPDATE Users SET weight = 160, desiredWeight = 145 WHERE id = 1;</code>
Ini menukar weight
dan desiredWeight
untuk pengguna dengan id = 1
tanpa menjejaskan entri lain.
Untuk mengendalikan kedua-dua sisipan dan pengemaskinian berdasarkan kewujudan rekod, pertimbangkan alternatif ini:
INSERT ... ON DUPLICATE KEY UPDATE
:<code class="language-sql">INSERT INTO Users (id, weight, desiredWeight) VALUES (1, 160, 145) ON DUPLICATE KEY UPDATE weight = 160, desiredWeight = 145;</code>
Ini memasukkan baris baharu jika kunci tidak wujud; jika tidak, ia mengemas kini baris sedia ada.
INSERT ... SET
: (Walaupun fungsinya serupa dengan kaedah VALUES di atas, sintaks ini selalunya kurang diutamakan untuk kejelasan)Ingat: Jika id
ialah lajur kenaikan automatik, anda boleh meninggalkannya daripada pernyataan INSERT; MySQL akan menjana ID unik secara automatik.
Atas ialah kandungan terperinci Mengapa INSERT Queries Gagal dengan Klausa WHERE dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!