Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Melakukan Kemas Kini Pukal dalam MySQL Menggunakan INSERT INTO ... PILIH ... PADA KEMASKINI KUNCI DUA?

Bagaimana untuk Melakukan Kemas Kini Pukal dalam MySQL Menggunakan INSERT INTO ... PILIH ... PADA KEMASKINI KUNCI DUA?

DDD
Lepaskan: 2024-12-13 00:56:17
asal
289 orang telah melayarinya

How to Perform Bulk Updates in MySQL Using INSERT INTO ... SELECT ... ON DUPLICATE KEY UPDATE?

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>, ...
Salin selepas log masuk

Di sini, merujuk kepada lajur dalam klausa INSERT INTO, manakala merujuk kepada lajur yang sepadan dalam klausa SELECT.

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

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!

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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan