InnoDB menyetel ulang bidang auto_increment saat Anda memulai ulang database.
Saat InnoDB dimulai ulang, ia menemukan nilai tertinggi di kolom dan kemudian memulai dari sana.
Ini tidak akan terjadi di MyISAM karena menyimpan id terakhir yang ditambahkan.
Perbarui
Fitur/bug ini telah ada sejak 2003 dan dapat menyebabkan masalah serius. Ambil contoh di bawah ini,
-
Tabel t1 memiliki kunci utama penyertaan otomatis.
-
Tabel t2 memiliki kolom untuk kunci utama di t1 tanpa "kendala" kunci asing. Dengan kata lain, ketika sebuah baris dihapus di t1 baris yang sesuai di t2 menjadi yatim piatu.
-
Seperti yang kita ketahui dengan InnoDB restart, sebuah id bisa diterbitkan kembali. Oleh karena itu, baris yatim piatu di t2 dapat ditautkan secara salah ke baris baru di t1.