Chưa bao giờ sử dụng Sphinx, nhưng đã thử MySQL 5.6 FTS trên bảng Innodb với khoảng 170 nghìn hàng. Tạo chỉ mục FTS trên cột tên (chứa tất cả tên của một người). Để tìm một từ ở bất kỳ vị trí nào của chuỗi MATCH(name) AGAINST("+word*") IN BOOLEAN MODE
hoạt động nhanh hơn rất nhiều (trong trường hợp của tôi là 2-3 lần) so với việc sử dụng name LIKE "word%" OR name LIKE "% word"
. Tuy nhiên, khi thực hiện các phép nối, hãy kiểm tra GIẢI THÍCH để xem chỉ số FTS có thực sự được sử dụng hay không. Có vẻ như trình tối ưu hóa MySQL không giỏi trong việc đoán khi nào nên sử dụng chỉ mục FTS.