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

वर्चर (अधिकतम) हर जगह?

VARCHAR(MAX) . का उपयोग करके आप मूल रूप से SQL सर्वर को बता रहे हैं "इस क्षेत्र में मूल्यों को संग्रहीत करें कि आप सबसे अच्छा कैसे देखते हैं", SQL सर्वर तब यह चुनेगा कि मानों को नियमित VARCHAR के रूप में संग्रहीत करना है या नहीं या एक LOB (बड़ी वस्तु) के रूप में। सामान्य रूप से यदि संग्रहीत मान 8,000 बाइट्स से कम हैं तो SQL सर्वर मानों को एक नियमित VARCHAR के रूप में मानेगा टाइप करें।

यदि संग्रहीत मान बहुत बड़े हैं तो कॉलम को पृष्ठ को LOB पृष्ठों में फैलाने की अनुमति है, ठीक उसी तरह जैसे वे अन्य LOB प्रकारों के लिए करते हैं (text , ntext और छवि ) - यदि ऐसा होता है तो अतिरिक्त पृष्ठों में संग्रहीत डेटा को पढ़ने के लिए अतिरिक्त पृष्ठ पढ़ने की आवश्यकता होती है (अर्थात एक प्रदर्शन दंडात्मक रूप से होता है), हालांकि यह केवल तभी होता है जब संग्रहीत मान बहुत बड़े हों

वास्तव में SQL सर्वर 2008 या बाद के डेटा के तहत निश्चित लंबाई के डेटा प्रकारों (जैसे VARCHAR(3,000) के साथ भी अतिरिक्त पृष्ठों पर अतिप्रवाह हो सकता है। ), हालांकि इन पृष्ठों को पंक्ति अतिप्रवाह डेटा पृष्ठ कहा जाता है और इनके साथ थोड़ा अलग व्यवहार किया जाता है।

लघु संस्करण: भंडारण के दृष्टिकोण से VARCHAR(MAX) . का उपयोग करने का कोई नुकसान नहीं है VARCHAR(N) . से अधिक कुछ N . के लिए ।

(ध्यान दें कि यह अन्य चर-लंबाई वाले फ़ील्ड प्रकारों पर भी लागू होता है NVARCHAR और वर्बिनरी )

FYI करें - आप VARCHAR(MAX)<पर इंडेक्स नहीं बना सकते /कोड> कॉलम



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL सर्वर में 'डेटाटाइमऑफ़सेट' संग्रहण आकार को समझना

  2. क्या टीएसक्यूएल एसक्यूएल सर्वर में संग्रहित प्रक्रिया की तुलना में तेजी से परिणाम लौटाएगा

  3. 4 कारण क्यों आपको अपनी 2020 की योजना में डेटाबेस निगरानी को प्राथमिकता देनी चाहिए

  4. विदेशी कुंजी बाधा चक्र या एकाधिक कैस्केड पथ का कारण बन सकती है?

  5. SQL सर्वर (T-SQL) में क्वेरी परिणाम ईमेल करते समय कॉलम हेडर कैसे निकालें