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

मारियाडीबी में एक तालिका के चरित्र सेट और संयोजन को सेट करें

आप MariaDB में विभिन्न स्तरों पर वर्ण सेट और संयोजन निर्दिष्ट कर सकते हैं। आप उन्हें कनेक्शन स्तर, सर्वर स्तर, डेटाबेस स्तर, तालिका स्तर और यहां तक ​​कि स्तंभ स्तर पर निर्दिष्ट कर सकते हैं।

आप अपने प्रश्नों में एक कोलाज भी निर्दिष्ट कर सकते हैं ताकि यह किसी भी ऐसे कोलाजेशन को ओवरराइड कर सके जिसे पहले उपरोक्त स्तरों पर निर्दिष्ट किया गया है।

तालिका स्तर पर वर्ण सेट और संयोजन सेट करने के लिए, CREATE TABLE का उपयोग करें स्टेटमेंट या ALTER TABLE स्टेटमेंट (इस पर निर्भर करता है कि आप टेबल बना रहे हैं या उसमें बदलाव कर रहे हैं)।

तालिका बनाते समय

तालिका बनाते समय संयोजन और वर्ण सेट सेट करने का एक उदाहरण यहां दिया गया है:

CREATE TABLE Products ( 
    ProductId CHAR(10), 
    ProductName VARCHAR(255) NOT NULL, 
    PRIMARY KEY (ProductId)) 
    CHARACTER SET latin1 
    COLLATE latin1_general_ci;

यह Products . नामक एक तालिका बनाता है एक latin1 . के साथ वर्ण सेट, और latin1_general_ci . का एक संयोजन ।

मौजूदा तालिका बदलें

मौजूदा टेबल पर सेट कोलेशन और कैरेक्टर को बदलने का एक उदाहरण यहां दिया गया है:

ALTER TABLE Products 
CONVERT TO CHARACTER SET utf8 COLLATE utf8_spanish_ci;

यह अब नए संयोजन और वर्ण सेट का उपयोग करता है।

CONVERT TO . को छोड़ना भी संभव है भाग:

ALTER TABLE Products 
CHARACTER SET utf8 
COLLATE utf8_spanish_ci;

संरेखण वर्ण सेट के लिए मान्य होना चाहिए

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

निर्दिष्ट वर्ण सेट के लिए अमान्य संयोजन का उपयोग करने का एक उदाहरण यहां दिया गया है:

ALTER TABLE Products 
CHARACTER SET latin1 
COLLATE utf8_spanish_ci;

परिणाम:

ERROR 1253 (42000): COLLATION 'utf8_spanish_ci' is not valid for CHARACTER SET 'latin1'

यह हमें बताता है कि हमारा चुना हुआ संयोजन हमारे चुने हुए निर्दिष्ट वर्ण सेट के लिए मान्य नहीं है।

मिलान कोलाज और कैरेक्टर सेट की सूची के लिए मारियाडीबी द्वारा समर्थित कोलाज की पूरी सूची या मारियाडीबी द्वारा समर्थित कैरेक्टर सेट की पूरी सूची देखें।

केवल संयोजन या वर्ण सेट निर्दिष्ट करना

केवल संयोजन या केवल वर्ण सेट (या न तो) निर्दिष्ट करना ठीक है:

  • यदि केवल वर्ण सेट प्रदान किया जाता है, तो उस वर्ण सेट के लिए डिफ़ॉल्ट संयोजन का उपयोग किया जाएगा।
  • यदि केवल संयोजन प्रदान किया जाता है, तो संबंधित वर्ण सेट का उपयोग किया जाएगा।
  • यदि न तो संयोजन और न ही वर्ण सेट प्रदान किया जाता है, तो तालिका डिफ़ॉल्ट का उपयोग किया जाता है।

ऐसे कैरेक्टर सेट में कनवर्ट करना जिसके लिए अधिक बाइट्स की आवश्यकता होती है

VARCHAR . के लिए या TEXT कॉलम, CONVERT TO CHARACTER SET यदि आवश्यक हो तो डेटा प्रकार बदलता है ताकि यह सुनिश्चित हो सके कि नया कॉलम मूल कॉलम के रूप में कई वर्णों को संग्रहीत करने के लिए पर्याप्त लंबा है।

उदाहरण के लिए, एक ascii TEXT कॉलम में प्रति वर्ण एक बाइट की आवश्यकता होती है, इसलिए कॉलम में 65,535 वर्ण तक हो सकते हैं। यदि कॉलम को utf8 में बदल दिया जाता है, तो प्रत्येक वर्ण के लिए 3 बाइट्स की आवश्यकता हो सकती है, इसलिए कॉलम को MEDIUMTEXT में बदल दिया जाएगा। (जिसकी अधिकतम लंबाई 16,777,215 है) ताकि वह उतने ही वर्णों को धारण कर सके।

यदि आप नहीं चाहते कि इस तरह के डेटा प्रकार में परिवर्तन हो, तो MODIFY . का उपयोग करें इसके बजाय अलग-अलग कॉलम पर।

उदाहरण के लिए:

ALTER TABLE Products 
MODIFY ProductName VARCHAR(255) 
CHARACTER SET utf8; 

बाइनरी में कनवर्ट करना

CONVERT TO CHARACTER SET binary CHAR में कनवर्ट करेगा , VARCHAR और TEXT BINARY . के लिए कॉलम , VARBINARY और BLOB क्रमश।

एक बार यह हो जाने के बाद, ऐसे स्तंभों में वर्ण सेट नहीं रहेगा। साथ ही, वे अब भविष्य के CONVERT TO CHARACTER SET . से प्रभावित नहीं होंगे बयान।

MariaDB में कोलेशन और कैरेक्टर सेट की जाँच करना

आप जिस स्तर की जांच कर रहे हैं (सर्वर, डेटाबेस, टेबल, कॉलम, कनेक्शन, आदि) के आधार पर, मारियाडीबी में संयोजन और चरित्र सेट की जांच करने के कई तरीके हैं। उदाहरण के लिए मारियाडीबी में कोलेशन दिखाएँ देखें।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मारियाडीबी CURRENT_USER () समझाया गया

  2. मारियाडीबी (प्रतिकृति और मारियाडीबी क्लस्टर) का उपयोग करके मूडल के लिए अत्यधिक उपलब्ध डेटाबेस बनाना

  3. MariaDB में समय मान से घंटे, मिनट और सेकंड को अलग करने के 4 तरीके

  4. मारियाडीबी SYSTEM_USER () समझाया गया

  5. मारियाडीबी JSON_ARRAY_APPEND() समझाया गया