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

Oracle और SQL सर्वर में NVARCHAR के बीच अंतर?

हाँ, यदि आपका Oracle डेटाबेस यूनिकोड वर्ण सेट का उपयोग करके बनाया गया है, तो एक NVARCHAR SQL सर्वर में एक VARCHAR2 में माइग्रेट किया जाना चाहिए ओरेकल में। Oracle में, NVARCHAR जब डेटाबेस कैरेक्टर सेट यूनिकोड का समर्थन नहीं करता है, तो डेटा प्रकार मौजूद होता है ताकि एप्लिकेशन को यूनिकोड कैरेक्टर सेट का उपयोग करके डेटा स्टोर करने की अनुमति मिल सके।

हालांकि, माइग्रेट करते समय एक बात का ध्यान रखना चाहिए, वह है कैरेक्टर लेंथ सेमेन्टिक्स। SQL सर्वर में, एक NVARCHAR(20) 20 वर्णों के लिए स्थान आवंटित करता है जिसके लिए UCS-2 में 40 बाइट्स तक की आवश्यकता होती है। Oracle में, डिफ़ॉल्ट रूप से, एक VARCHAR2(20) भंडारण के 20 बाइट्स आवंटित करता है। AL32UTF8 . में वर्ण सेट, यह संभावित रूप से केवल 6 वर्णों के लिए पर्याप्त स्थान है, हालांकि सबसे अधिक संभावना है कि यह बहुत अधिक संभाल लेगा (AL32UTF8 में एक एकल वर्ण) 1 और 3 बाइट्स के बीच की आवश्यकता है। आप शायद अपने Oracle प्रकारों को VARCHAR2(20 CHAR) . के रूप में घोषित करना चाहते हैं जो इंगित करता है कि आप 20 वर्णों के लिए स्थान आवंटित करना चाहते हैं, भले ही कितने बाइट्स की आवश्यकता हो। यह समझाने की कोशिश करने की तुलना में संवाद करना बहुत आसान हो जाता है कि क्यों कुछ 20 वर्ण स्ट्रिंग की अनुमति है जबकि अन्य 10 वर्ण स्ट्रिंग अस्वीकार कर दी गई हैं।

आप सत्र स्तर पर डिफ़ॉल्ट लंबाई शब्दार्थ को बदल सकते हैं ताकि कोई भी तालिका जो आप बिना किसी लंबाई के शब्दार्थ को निर्दिष्ट किए बनाते हैं, वह बाइट शब्दार्थ के बजाय वर्ण का उपयोग करेगी

ALTER SESSION SET nls_length_semantics=CHAR;

इससे आप CHAR typing लिखने से बच सकते हैं हर बार जब आप एक नया कॉलम परिभाषित करते हैं। इसे सिस्टम स्तर पर सेट करना भी संभव है, लेकिन ऐसा करने से NLS टीम द्वारा हतोत्साहित किया जाता है-- जाहिर है, Oracle द्वारा प्रदान की जाने वाली सभी स्क्रिप्ट का डेटाबेस के विरुद्ध पूरी तरह से परीक्षण नहीं किया गया है, जहां NLS_LENGTH_SEMANTICS बदल दिया गया है। और शायद बहुत कम तृतीय-पक्ष स्क्रिप्ट हैं।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle में DateDiff() का उपयोग करना

  2. NLSLANG को बिना हजार सेपरेटर के सेट करें

  3. Oracle VARCHAR कॉलम पर संख्यात्मक तुलना कैसे काम करती है?

  4. अद्यतन oracle कथन काम नहीं करता

  5. Visual Studio 2017 में Oracle Attunity ड्राइवर स्थापित करें