Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

क्या MySQL में तुलना करते समय इसे varchar या varchar से int में बदलना तेज़ है?

यह इंडेक्स पर निर्भर करता है। अगर दोनों कॉलम में इंडेक्स सेट हैं, तो आपको int . पर कास्ट करना चाहिए , क्योंकि इसे केवल 4 बाइट्स की तुलना करने की आवश्यकता है। यदि, तथापि, केवल varchar कॉलम को अनुक्रमित किया जाता है, varchar . पर डाला जाता है ।

अंत में, आपके पास अपनी क्वेरी होनी चाहिए explain एड, यह देखने के लिए कि किस इंडेक्स का उपयोग किया जाता है, और उसके अनुसार कास्ट करें।

यदि कोई अनुक्रमणिका सेट नहीं है, तो int . पर कास्ट करें सामान्य तौर पर बेहतर तरीका है। हालांकि, अगर कोई इंडेक्स सेट नहीं है, तो इससे कोई फर्क नहीं पड़ता, आप कास्ट करने का सही तरीका चुनने की तुलना में इंडेक्सिंग करके ज्यादा समय बचाएंगे। सिवाय, फिर से, टेबल छोटे हैं। फिर, यह वास्तव में भी कोई मायने नहीं रखता।

वास्तव में, हमें न केवल तुलना के लिए, बल्कि कास्टिंग के लिए भी लागतों को ध्यान में रखना चाहिए:एक int कास्टिंग करना एक varchar . के लिए varchar . को पार्स करने से थोड़ा तेज़ है एक int . के लिए . हालांकि, कम से कम 4 वर्णों वाले वर्चर की तुलना करना उस लाभ को बेकार कर देगा। यदि आपके मान 999 से अधिक हैं, तो int . पर कास्ट करें तेज होगा। लेकिन यह अब आपके ऑपरेटिंग सिस्टम, आर्किटेक्चर, आपके MySQL बाइनरी द्वारा उपयोग किए जाने वाले निर्देश सेट आदि पर निर्भर करता है। वास्तव में विश्वसनीय उत्तर पाने का एकमात्र तरीका है:लक्ष्य मशीन पर उस स्थिति को बेंचमार्क करें।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मैसकल फंक्शन कॉल

  2. हाइबरनेट के साथ डीबी को एनम वैल्यू कैसे सेव करें?

  3. मुझे Django में MySQL सर्वर अपवाद क्यों हो रहा है?

  4. MySQL - एक रिकॉर्ड की पंक्ति संख्या का चयन करें

  5. प्रति दिनांक अंतराल पर अद्वितीय विज़िटर कैसे चुनें?