Saya menggunakan teknik Leonard Challis dengan beberapa perubahan:
CREATE TEMPORARY TABLE tmptable_1 SELECT * FROM table WHERE primarykey = 1;
UPDATE tmptable_1 SET primarykey = NULL;
INSERT INTO table SELECT * FROM tmptable_1;
DROP TEMPORARY TABLE IF EXISTS tmptable_1;
Sebagai tabel sementara, tidak boleh ada lebih dari satu catatan, jadi Anda tidak perlu khawatir tentang kunci utama. Menyetelnya ke null memungkinkan MySQL untuk memilih nilainya sendiri, sehingga tidak ada risiko membuat duplikat.
Jika Anda ingin sangat yakin bahwa Anda hanya mendapatkan satu baris untuk disisipkan, Anda dapat menambahkan LIMIT 1 ke akhir baris INSERT INTO.
Perhatikan bahwa saya juga menambahkan nilai kunci utama (1 dalam kasus ini) ke nama tabel sementara saya.