Di InnoDB, update
pernyataan mengunci setiap baris yang mereka pindai. Ini berarti bahwa untuk memperbarui 200 baris Anda, itu harus membuat 350.000 kunci tingkat baris, sambil menjaga kunci rollback pada saat yang sama dan memberikan nilai sebelumnya ke setiap transaksi yang membaca nilai yang sudah diubah (karena transaksi tidak berkomitmen dan perubahan belum final)
MyISAM di sisi lain mengunci seluruh tabel.
Jadi, jika Anda perlu memperbarui semua baris, kunci seluruh tabel, dan Anda akan mendapatkan kinerja yang jauh lebih baik (Anda tidak memerlukan kunci tingkat baris)
Tetapi lebih baik lagi, berikan klausa WHERE, seperti yang Anda lakukan, dan InnoDB akan memperoleh kunci hanya untuk baris yang cocok (serta beberapa kunci celah di pohon indeks, tetapi ini di luar cakupan pertanyaan)