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

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

मारियाडीबी में, COMPRESS() एक अंतर्निहित फ़ंक्शन है जो एक स्ट्रिंग को संपीड़ित करता है और परिणाम को बाइनरी स्ट्रिंग के रूप में देता है।

COMPRESS() फ़ंक्शन की आवश्यकता है कि मारियाडीबी को एक संपीड़न पुस्तकालय जैसे कि zlib के साथ संकलित किया गया हो। यदि मारियाडीबी को ऐसी कम्प्रेशन लाइब्रेरी के साथ संकलित नहीं किया गया है, तो COMPRESS() रिटर्न null

सिंटैक्स

वाक्य रचना इस प्रकार है:

COMPRESS(string_to_compress)

जहां string_to_compress वह स्ट्रिंग है जिसे आप संपीड़ित करना चाहते हैं।

उदाहरण

यहां एक बुनियादी उदाहरण दिया गया है:

SELECT
    LENGTH(REPEAT('z', 50)) AS "Uncompressed",
    LENGTH(COMPRESS(REPEAT('z', 50))) AS "Compressed";

परिणाम:

+--------------+------------+
| Uncompressed | Compressed |
+--------------+------------+
|           50 |         16 |
+--------------+------------+

यहाँ, मैंने LENGTH() . का उपयोग किया है क्रमशः असम्पीडित और संपीड़ित तारों के बाइट्स में लंबाई प्राप्त करने के लिए कार्य करें। मैंने REPEAT() . का उपयोग किया है एक ही अक्षर को संपीड़ित करने से पहले 50 बार दोहराने का कार्य करता है।

यहां एक और उदाहरण दिया गया है जो कॉपीराइट प्रतीक का उपयोग करता है (© ):

SELECT
    LENGTH(REPEAT('©', 50)) AS "Uncompressed",
    LENGTH(COMPRESS(REPEAT('©', 50))) AS "Compressed";

परिणाम:

+--------------+------------+
| Uncompressed | Compressed |
+--------------+------------+
|          100 |         17 |
+--------------+------------+

कॉपीराइट प्रतीक एक दो-बाइट वर्ण है, और इसकी असम्पीडित लंबाई एकल-बाइट वर्ण के आकार से दोगुनी है। हालांकि, दोहराए गए दो-बाइट वर्णों की इस स्ट्रिंग को संपीड़ित करने से यह दोहराए गए सिंगल-बाइट वर्णों की संपीड़ित स्ट्रिंग के समान आकार में आ जाता है।

यहां एक तीन-बाइट वर्ण का उपयोग किया गया है:

SELECT
    LENGTH(REPEAT('อ', 50)) AS "Uncompressed",
    LENGTH(COMPRESS(REPEAT('อ', 50))) AS "Compressed";

परिणाम:

+--------------+------------+
| Uncompressed | Compressed |
+--------------+------------+
|          150 |         18 |
+--------------+------------+

इस मामले में, प्रभाव और भी अधिक है। दोहराए गए तीन-बाइट वर्ण स्ट्रिंग पिछले उदाहरणों में दोहराए गए एक और दो-बाइट वर्ण स्ट्रिंग के समान आकार में कम हो जाते हैं।

अशक्त तर्क

पासिंग null रिटर्न null :

SELECT COMPRESS(null);

परिणाम:

+----------------+
| COMPRESS(null) |
+----------------+
| NULL           |
+----------------+

अनुपलब्ध तर्क

कॉलिंग COMPRESS() तर्कों की गलत संख्या के साथ, या बिना कोई तर्क पारित किए त्रुटि उत्पन्न होती है:

SELECT COMPRESS();

परिणाम:

ERROR 1582 (42000): Incorrect parameter count in the call to native function 'COMPRESS'

संपीड़न की जांच करें

जैसा कि बताया गया है, COMPRESS() फ़ंक्शन की आवश्यकता है कि मारियाडीबी को एक संपीड़न पुस्तकालय जैसे कि zlib के साथ संकलित किया गया हो। यदि मारियाडीबी को ऐसी कम्प्रेशन लाइब्रेरी के साथ संकलित नहीं किया गया है, तो COMPRESS() रिटर्न null

आप have_compress . की जांच कर सकते हैं सिस्टम चर यह देखने के लिए कि क्या zlib संपीड़न पुस्तकालय सर्वर के लिए सुलभ है या नहीं:

SELECT @@have_compress;

परिणाम:

+-----------------+
| @@have_compress |
+-----------------+
| YES             |
+-----------------+

इस मामले में, zlib संपीड़न पुस्तकालय सर्वर के लिए सुलभ है, और परिणाम YES . है .

यदि zlib कम्प्रेशन लाइब्रेरी सर्वर तक पहुँच योग्य नहीं है, तो परिणाम NO . होगा ।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Laravel:निर्दिष्ट कुंजी बहुत लंबी थी; अधिकतम कुंजी लंबाई 767 बाइट्स है

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

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

  4. मारियाडीबी द्वारा समर्थित कोलाज की पूरी सूची

  5. मारियाडीबी में सबडेट () कैसे काम करता है?