OR
. के लिए क्वेरी योजना मामला इंगित करता है कि MySQL
वास्तव में अनुक्रमणिका का उपयोग कर रहा है, तो जाहिर है हाँ, यह कम से कम इस मामले में कर सकता है। यह पूरी तरह से उचित लगता है, क्योंकि seen
. पर एक अनुक्रमणिका है , और id
पीके है।
यदि "तार्किक और उचित स्पष्टीकरण" वास्तविकता से विरोधाभासी हैं, तो यह मान लेना सुरक्षित है कि तर्क त्रुटिपूर्ण है या स्पष्टीकरण गलत या अनुपयुक्त हैं। प्रदर्शन की भविष्यवाणी करना बेहद मुश्किल है; जहां गति महत्वपूर्ण है वहां प्रदर्शन परीक्षण आवश्यक है।
आपको उसी का उपयोग करना चाहिए जिसका परीक्षण . है इनपुट पर तेजी से जो पर्याप्त रूप से मॉडल करता है जिसे प्रोग्राम वास्तविक उपयोग में देखेगा।
हालाँकि, यह भी ध्यान दें कि आपके दो प्रश्न शब्दार्थ रूप से समतुल्य नहीं हैं:यदि id = 5204
वाली पंक्ति seen = 3
भी है फिर OR
query इसे एक बार वापस कर देगी, लेकिन UNION ALL
query इसे दो बार वापस कर देगा। किसी भी आधार पर सही कोड और गलत कोड के बीच चयन करना व्यर्थ है, सिवाय इसके कि कौन सा सही है।