Pengoptimal MySQL akan memutuskan urutan/metode bergabung terlebih dahulu, dan kemudian memeriksa apakah, untuk urutan gabung yang dipilih, dimungkinkan untuk menghindari pengurutan dengan menggunakan indeks. Untuk kueri lambat dalam pertanyaan ini, pengoptimal telah memutuskan untuk menggunakan gabungan Block-Nested-Loop (BNL).
BNL biasanya lebih cepat daripada menggunakan indeks ketika salah satu tabel sangat kecil (dan tidak ada LIMIT).
Namun, dengan BNL, baris tidak harus datang dalam urutan yang diberikan oleh tabel pertama. Oleh karena itu, hasil gabungan perlu diurutkan sebelum menerapkan LIMIT.
Anda dapat mematikan BNL dengan set optimizer_switch = 'block_nested_loop=off';