Melaksanakan Kemas Kini Pukal dengan INSERT INTO ... PILIH DARIPADA ... PADA KEMASKINI KUNCI DUA
Apabila cuba memasukkan data baharu ke dalam jadual, mungkin terdapat keadaan di mana rekod sedia ada dengan kunci unik yang sama perlu dikemas kini dengan nilai terkini. MySQL menyediakan sintaks yang mudah untuk senario sedemikian menggunakan INSERT INTO ... SELECT FROM ... ON DUPLICATE KEY UPDATE statement.
Dalam kes anda, anda perlu mengemas kini semua lajur kecuali exp_id, created_by, location, animal , masa mula dan masa tamat. Sintaks untuk klausa kemas kini ini ialah:
ON DUPLICATE KEY UPDATE <column_name>=<select_column_name>, ...
Di sini,
Berdasarkan pertanyaan anda, pernyataan lengkap akan kelihatan seperti ini:
INSERT INTO lee(exp_id, created_by, location, animal, starttime, endtime, entct, inact, inadur, inadist, smlct, smldur, smldist, larct, lardur, lardist, emptyct, emptydur) SELECT id, uid, t.location, t.animal, t.starttime, t.endtime, t.entct, t.inact, t.inadur, t.inadist, t.smlct, t.smldur, t.smldist, t.larct, t.lardur, t.lardist, t.emptyct, t.emptydur FROM tmp t WHERE uid=x ON DUPLICATE KEY UPDATE entct=t.entct, inact=t.inact, inadur=t.inadur, inadist=t.inadist, smlct=t.smlct, smldur=t.smldur, smldist=t.smldist, larct=t.larct, lardur=t.lardur, lardist=t.lardist, emptyct=t.emptyct, emptydur=t.emptydur;
Dengan pernyataan ini, MySQL akan memasukkan data daripada tmp ke dalam lee, dan jika kunci pendua ditemui, ia akan mengemas kini lajur yang ditentukan dengan nilai daripada pernyataan SELECT.
Atas ialah kandungan terperinci Bagaimana untuk Melakukan Kemas Kini Pukal dalam MySQL Menggunakan INSERT INTO ... PILIH ... PADA KEMASKINI KUNCI DUA?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!