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

मारियाडीबी में संयोजन दिखाएं

मारियाडीबी में, कई स्तरों पर संयोजन लागू किया जा सकता है। Collation को सर्वर स्तर, कनेक्शन स्तर, डेटाबेस स्तर, तालिका स्तर और यहां तक ​​कि स्तंभ स्तर पर भी लागू किया जा सकता है।

क्वेरी स्तर पर एक कॉलेशन निर्दिष्ट करना भी संभव है, ताकि यह डेटाबेस, टेबल या कॉलम लेवल पर लागू किए गए किसी भी कॉलेशन को ओवरराइड कर सके।

मारियाडीबी विभिन्न स्तरों पर संयोजन को वापस करने के लिए कई विकल्प प्रदान करता है।

कनेक्शन, सर्वर और डेटाबेस कोलेशन दिखाएं

हम SHOW VARIABLES का उपयोग कर सकते हैं LIKE . के साथ प्रशासनिक विवरण वेरिएबल्स को वापस करने के लिए क्लॉज जिसमें उनके नाम के भीतर एक निश्चित स्ट्रिंग शामिल है।

उदाहरण:

SHOW VARIABLES LIKE 'collation%';

उदाहरण परिणाम:

+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | utf8_general_ci    |
| collation_database   | utf8mb4_general_ci |
| collation_server     | utf8mb4_general_ci |
+----------------------+--------------------+

ये वे परिणाम हैं जो मुझे अपने परीक्षण वातावरण में मिलते हैं। आपको मिलने वाला परिणाम आपकी सेटिंग पर निर्भर करेगा।

यदि आवश्यक हो तो इन अलग-अलग चरों में से प्रत्येक को अलग से लौटाया जा सकता है (नीचे देखें)।

डिफ़ॉल्ट रूप से, SHOW VARIABLES SESSION दिखाता है चर। इस मामले में, यह उन मानों को लौटाता है जो वर्तमान कनेक्शन के लिए प्रभावी हैं।

इसलिए, पिछले उदाहरण को निम्नानुसार फिर से लिखा जा सकता है:

SHOW SESSION VARIABLES LIKE 'collation%';

उदाहरण परिणाम:

+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | utf8_general_ci    |
| collation_database   | utf8mb4_general_ci |
| collation_server     | utf8mb4_general_ci |
+----------------------+--------------------+

वैकल्पिक रूप से, आप SESSION . को बदल सकते हैं LOCAL . के साथ (जो SESSION . का समानार्थी है ):

SHOW LOCAL VARIABLES LIKE 'collation%';

आप GLOBAL का भी उपयोग कर सकते हैं मारियाडीबी के नए कनेक्शन के लिए उपयोग किए जाने वाले मानों को प्रदर्शित करने के लिए संशोधक।

उदाहरण:

SHOW GLOBAL VARIABLES LIKE 'collation%';

उदाहरण परिणाम:

+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | utf8mb4_general_ci |
| collation_database   | utf8mb4_general_ci |
| collation_server     | utf8mb4_general_ci |
+----------------------+--------------------+

सर्वर संयोजन

निम्न आदेश सर्वर का डिफ़ॉल्ट संयोजन लौटाता है:

SELECT @@collation_server;

उदाहरण परिणाम:

+--------------------+
| @@collation_server |
+--------------------+
| utf8mb4_general_ci |
+--------------------+

कनेक्शन-लेवल कोलेशन

जब आप मारियाडीबी डेटाबेस के खिलाफ एक क्वेरी चलाते हैं, तो मारियाडीबी सिस्टम चर के एक समूह का उपयोग करता है ताकि यह निर्धारित किया जा सके कि जब भी प्रश्न चलाए जाते हैं तो कौन सा वर्ण सेट और संयोजन का उपयोग करना है। यदि क्लाइंट सर्वर के लिए एक अलग वर्ण सेट का उपयोग करता है, तो मारियाडीबी इसे एक उपयुक्त वर्ण सेट और संयोजन में अनुवाद कर सकता है।

क्लाइंट को क्वेरी परिणाम वापस भेजते समय, मारियाडीबी इन परिणामों को आवश्यकता पड़ने पर पूरी तरह से एक अलग वर्ण सेट में अनुवाद कर सकता है। इनमें से प्रत्येक चरण में कौन से वर्ण सेट और कॉलेशन का उपयोग करना है, यह निर्धारित करने के लिए MariaDB सिस्टम चर का उपयोग करता है।

निम्नलिखित कनेक्शन संयोजन को अलग करता है (आप किसी भी सिस्टम चर के लिए समान सिंटैक्स का उपयोग कर सकते हैं):

SELECT @@collation_connection;

उदाहरण परिणाम:

+------------------------+
| @@collation_connection |
+------------------------+
| utf8_general_ci        |
+------------------------+

आप निम्न क्वेरी के साथ सभी वर्ण सेट सिस्टम चर भी वापस कर सकते हैं:

SHOW VARIABLES LIKE 'character_set%';

परिणाम:

+--------------------------+--------------------------------------------------------+
| Variable_name            | Value                                                  |
+--------------------------+--------------------------------------------------------+
| character_set_client     | utf8                                                   |
| character_set_connection | utf8                                                   |
| character_set_database   | utf8mb4                                                |
| character_set_filesystem | binary                                                 |
| character_set_results    | utf8                                                   |
| character_set_server     | utf8mb4                                                |
| character_set_system     | utf8                                                   |
| character_sets_dir       | /usr/local/Cellar/mariadb/10.5.9/share/mysql/charsets/ |
+--------------------------+--------------------------------------------------------+

डेटाबेस-स्तर का मिलान

किसी दिए गए डेटाबेस के मिलान की जाँच के लिए निम्नलिखित कथन का उपयोग किया जा सकता है:

USE PetHouse;
SELECT @@character_set_database, @@collation_database;

उदाहरण परिणाम:

+--------------------------+----------------------+
| @@character_set_database | @@collation_database |
+--------------------------+----------------------+
| utf8mb4                  | utf8mb4_general_ci   |
+--------------------------+----------------------+

इसे करने का एक और तरीका है, इस तरह के एक बयान का उपयोग करना:

SELECT 
    default_character_set_name, 
    default_collation_name 
FROM information_schema.schemata 
WHERE schema_name = 'PetHouse';

उदाहरण परिणाम:

+----------------------------+------------------------+
| default_character_set_name | default_collation_name |
+----------------------------+------------------------+
| utf8mb4                    | utf8mb4_general_ci     |
+----------------------------+------------------------+

इस दूसरी विधि का उपयोग करने से आप डेटाबेस को स्विच किए बिना परिणाम प्राप्त कर सकते हैं।

यहाँ यह एक भिन्न डेटाबेस का उपयोग कर रहा है:

SELECT 
    default_character_set_name, 
    default_collation_name 
FROM information_schema.schemata 
WHERE schema_name = 'test';

उदाहरण परिणाम:

+----------------------------+------------------------+
| default_character_set_name | default_collation_name |
+----------------------------+------------------------+
| latin1                     | latin1_swedish_ci      |
+----------------------------+------------------------+

यह परीक्षण डेटाबेस है जो तब बनाया गया था जब मैंने पहली बार मारियाडीबी स्थापित किया था।

टेबल-लेवल कोलेशन

निम्नलिखित कथन कई कॉलम देता है जो किसी भी मिलान तालिका के बारे में जानकारी प्रदान करते हैं। इनमें से एक कॉलम को Collation . कहा जाता है , और यह सभी मेल खाने वाली तालिकाओं का मिलान प्रदान करता है।

SHOW TABLE STATUS LIKE '%Pets%';

उदाहरण परिणाम (ऊर्ध्वाधर आउटपुट का उपयोग करके):

*************************** 1. row ***************************
            Name: Pets
          Engine: InnoDB
         Version: 10
      Row_format: Dynamic
            Rows: 8
  Avg_row_length: 2048
     Data_length: 16384
 Max_data_length: 0
    Index_length: 32768
       Data_free: 0
  Auto_increment: NULL
     Create_time: 2021-03-30 09:10:38
     Update_time: 2021-03-30 09:16:39
      Check_time: NULL
       Collation: utf8mb4_general_ci
        Checksum: NULL
  Create_options: 
         Comment: 
Max_index_length: 0
       Temporary: N

इस मामले में, मुझे Pets . नामक तालिका के बारे में जानकारी मिली है . हम देख सकते हैं कि Collation कॉलम में utf8mb4_general_ci है , जो तालिका का संयोजन है।

यह कथन अन्य खंडों को भी स्वीकार करता है, जैसे FROM , WHERE , और IN , इसलिए यह आपको अपना कथन बनाते समय कुछ विकल्प देता है।

अपनी तालिकाओं के बारे में मिलान जानकारी प्राप्त करने का दूसरा तरीका information_schema.tables के विरुद्ध क्वेरी चलाना है :

SELECT 
    table_schema, 
    table_name, 
    table_collation 
FROM information_schema.tables 
WHERE table_schema = 'PetHouse';

उदाहरण परिणाम:

+--------------+---------------+--------------------+
| table_schema | table_name    | table_collation    |
+--------------+---------------+--------------------+
| pethouse     | vpettypecount | NULL               |
| pethouse     | Pets          | utf8mb4_general_ci |
| pethouse     | Owners        | utf8mb4_general_ci |
| pethouse     | PetTypes      | utf8mb4_general_ci |
+--------------+---------------+--------------------+

स्तंभ-स्तर का मिलान

निम्नलिखित क्वेरी को चलाने से Pets में प्रत्येक कॉलम के बारे में जानकारी मिलती है टेबल। इसमें मिलान जानकारी शामिल है।

SHOW FULL COLUMNS FROM Pets;

उदाहरण परिणाम:

+-----------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
| Field     | Type        | Collation          | Null | Key | Default | Extra | Privileges                      | Comment |
+-----------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+
| PetId     | int(11)     | NULL               | NO   | PRI | NULL    |       | select,insert,update,references |         |
| PetTypeId | int(11)     | NULL               | NO   | MUL | NULL    |       | select,insert,update,references |         |
| OwnerId   | int(11)     | NULL               | NO   | MUL | NULL    |       | select,insert,update,references |         |
| PetName   | varchar(60) | utf8mb4_general_ci | NO   |     | NULL    |       | select,insert,update,references |         |
| DOB       | date        | NULL               | YES  |     | NULL    |       | select,insert,update,references |         |
+-----------+-------------+--------------------+------+-----+---------+-------+---------------------------------+---------+

वैकल्पिक रूप से, हम information_schema.columns . को क्वेरी कर सकते हैं . इस मामले में, हम केवल वे कॉलम चुन सकते हैं जिनमें हमारी रुचि है:

SELECT 
    column_name, 
    character_set_name, 
    collation_name 
FROM information_schema.columns
WHERE table_name = 'Pets';

उदाहरण परिणाम:

+-------------+--------------------+--------------------+
| column_name | character_set_name | collation_name     |
+-------------+--------------------+--------------------+
| PetId       | NULL               | NULL               |
| PetTypeId   | NULL               | NULL               |
| OwnerId     | NULL               | NULL               |
| PetName     | utf8mb4            | utf8mb4_general_ci |
| DOB         | NULL               | NULL               |
+-------------+--------------------+--------------------+

और हमारे टूलकिट में एक और विकल्प है CREATE TABLE . की जांच करना हमारी तालिका का बयान।

इस तरह:

SHOW CREATE TABLE Pets;

परिणाम:

+-------+------------------------------+
| Table | Create Table                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
+-------+------------------------------+
| Pets  | CREATE TABLE `Pets` (
  `PetId` int(11) NOT NULL,
  `PetTypeId` int(11) NOT NULL,
  `OwnerId` int(11) NOT NULL,
  `PetName` varchar(60) NOT NULL,
  `DOB` date DEFAULT NULL,
  PRIMARY KEY (`PetId`),
  KEY `PetTypeId` (`PetTypeId`),
  KEY `OwnerId` (`OwnerId`),
  CONSTRAINT `pets_ibfk_1` FOREIGN KEY (`PetTypeId`) REFERENCES `PetTypes` (`PetTypeId`),
  CONSTRAINT `pets_ibfk_2` FOREIGN KEY (`OwnerId`) REFERENCES `Owners` (`OwnerId`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 |
+-------+-------------------------------+

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

आइए मिलान को बदलें:

ALTER TABLE Pets 
MODIFY PetName VARCHAR(255) 
    CHARACTER SET utf8 COLLATE utf8_spanish_ci NOT NULL;

और SHOW CREATE TABLE run चलाएं फिर से:

SHOW CREATE TABLE Pets;

परिणाम:

+-------+------------------------------+
| Table | Create Table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
+-------+------------------------------+
| Pets  | CREATE TABLE `Pets` (
  `PetId` int(11) NOT NULL,
  `PetTypeId` int(11) NOT NULL,
  `OwnerId` int(11) NOT NULL,
  `PetName` varchar(255) CHARACTER SET utf8 COLLATE utf8_spanish_ci NOT NULL,
  `DOB` date DEFAULT NULL,
  PRIMARY KEY (`PetId`),
  KEY `PetTypeId` (`PetTypeId`),
  KEY `OwnerId` (`OwnerId`),
  CONSTRAINT `pets_ibfk_1` FOREIGN KEY (`PetTypeId`) REFERENCES `PetTypes` (`PetTypeId`),
  CONSTRAINT `pets_ibfk_2` FOREIGN KEY (`OwnerId`) REFERENCES `Owners` (`OwnerId`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 |
+-------+-------------------------------+

इस बार हम PetName . के विरुद्ध नए वर्ण सेट और संयोजन सेटिंग देख सकते हैं कॉलम।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. डेबियन और उबंटू पर मारियाडीबी 10 कैसे स्थापित करें

  2. कैसे CONCAT () मारियाडीबी में काम करता है

  3. मारियाडीबी ROW_COUNT () समझाया गया

  4. मारियाडीबी कॉलमस्टोर की विशेषता वाली नई मारियाडीबी एएक्स रिलीज 1.1.3 जीए

  5. Ubuntu 16.04 पर MariaDB 10.0 से 10.3.9 का उन्नयन