एक इंडेक्स क्वेरी को गति नहीं देगा, क्योंकि टेक्स्ट कॉलम के लिए इंडेक्स बाएं से शुरू होने वाले एन अक्षरों को इंडेक्स करके काम करते हैं। जब आप LIKE '%text%' करते हैं तो यह अनुक्रमणिका का उपयोग नहीं कर सकता क्योंकि पाठ से पहले वर्णों की एक चर संख्या हो सकती है।
आपको जो करना चाहिए वह इस तरह की क्वेरी का बिल्कुल भी उपयोग नहीं करना है। इसके बजाय आपको FTS (पूर्ण पाठ खोज) जैसे कुछ का उपयोग करना चाहिए जो MySQL MyISAM तालिकाओं के लिए समर्थन करता है। गैर-MyISAM तालिकाओं के लिए ऐसी अनुक्रमण प्रणाली को स्वयं बनाना भी बहुत आसान है, आपको बस एक अलग अनुक्रमणिका तालिका की आवश्यकता है जहां आप वास्तविक तालिका में शब्दों और उनकी प्रासंगिक आईडी संग्रहीत करते हैं।
अपडेट करें
MySQL 5.6+ के साथ InnoDB तालिकाओं के लिए पूर्ण पाठ खोज उपलब्ध है।