Gần đây tôi đã gặp phải vấn đề tương tự:MySQL bắt đầu bị nghẹt (mắc kẹt trong 'thống kê' trạng thái) trên các truy vấn có rất nhiều bảng được kết hợp với nhau. Tôi đã tìm thấy một bài đăng trên blog tốt giải thích tại sao điều này xảy ra và cách giải quyết.
Về cơ bản, ít nhất trong MySQL 5.5, giá trị mặc định cho tham số cấu hình Optimizer_search_depth là 62 sẽ khiến trình tối ưu hóa truy vấn mất nhiều thời gian hơn theo cấp số nhân khi số lượng bảng trong truy vấn tăng lên. Sau một thời điểm nhất định, sẽ bắt đầu mất nhiều ngày hoặc thậm chí lâu hơn để hoàn thành truy vấn.
Tuy nhiên, nếu bạn đặt Optimizer_search_depth đến 0 trong my.cnf của bạn , MySQL tự động chọn độ sâu phù hợp, nhưng giới hạn ở mức 7, chưa quá phức tạp.
Rõ ràng sự cố này đã được khắc phục trong MySQL 5.6 nhưng tôi chưa tự kiểm tra nó.