कैसेंड्रा - सीक्यूएल संग्रह

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

सूची

सूची का उपयोग उन मामलों में किया जाता है जहां

  • तत्वों का क्रम बनाए रखा जाना है, और
  • एक मान कई बार संग्रहीत किया जाना है।

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

सूची के साथ एक तालिका बनाना

नीचे दिए गए दो कॉलम, नाम और ईमेल के साथ एक नमूना तालिका बनाने के लिए एक उदाहरण है। कई ईमेल संग्रहीत करने के लिए, हम सूची का उपयोग कर रहे हैं।

cqlsh:tutorialspoint> CREATE TABLE data(name text PRIMARY KEY, email list<text>);

सूची में डेटा सम्मिलित करना

किसी सूची में तत्वों में डेटा सम्मिलित करते समय, नीचे दिखाए गए अनुसार वर्ग ब्रेस के भीतर अल्पविराम द्वारा अलग किए गए सभी मान दर्ज करें।

cqlsh:tutorialspoint> INSERT INTO data(name, email) VALUES ('ramu',
['[email protected]','[email protected]'])

एक सूची अद्यतन करना

नीचे दी गई तालिका में सूची डेटा प्रकार को अद्यतन करने के लिए एक उदाहरण है data। यहां हम सूची में एक और ईमेल जोड़ रहे हैं।

cqlsh:tutorialspoint> UPDATE data
... SET email = email +['[email protected]']
... where name = 'ramu';

सत्यापन

यदि आप SELECT स्टेटमेंट का उपयोग करके तालिका को सत्यापित करते हैं, तो आपको निम्न परिणाम प्राप्त होंगे -

cqlsh:tutorialspoint> SELECT * FROM data;

 name | email
------+--------------------------------------------------------------
 ramu | ['[email protected]', '[email protected]', '[email protected]']

(1 rows)

सेट

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

सेट के साथ एक तालिका बनाना

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

cqlsh:tutorialspoint> CREATE TABLE data2 (name text PRIMARY KEY, phone set<varint>);

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

एक सेट में तत्वों में डेटा सम्मिलित करते समय, नीचे दिखाए गए अनुसार घुंघराले ब्रेस {} के भीतर अल्पविराम द्वारा अलग किए गए सभी मान दर्ज करें।

cqlsh:tutorialspoint> INSERT INTO data2(name, phone)VALUES ('rahman',    {9848022338,9848022339});

एक सेट को अद्यतन करना

निम्न कोड दिखाता है कि डेटा 2 नामक तालिका में सेट को कैसे अपडेट किया जाए। यहां हम सेट पर एक और फोन नंबर जोड़ रहे हैं।

cqlsh:tutorialspoint> UPDATE data2
   ... SET phone = phone + {9848022330}
   ... where name = 'rahman';

सत्यापन

यदि आप SELECT स्टेटमेंट का उपयोग करके तालिका को सत्यापित करते हैं, तो आपको निम्न परिणाम प्राप्त होंगे -

cqlsh:tutorialspoint> SELECT * FROM data2;

   name | phone
--------+--------------------------------------
 rahman | {9848022330, 9848022338, 9848022339}

(1 rows)

नक्शा

मानचित्र एक डेटा प्रकार है जिसका उपयोग तत्वों के एक महत्वपूर्ण-मूल्य जोड़ी को संग्रहीत करने के लिए किया जाता है।

मानचित्र के साथ एक तालिका बनाना

निम्न उदाहरण दिखाता है कि दो कॉलम, नाम और पते के साथ एक नमूना तालिका कैसे बनाई जाए। कई पता मानों को संग्रहीत करने के लिए, हम मानचित्र का उपयोग कर रहे हैं।

cqlsh:tutorialspoint> CREATE TABLE data3 (name text PRIMARY KEY, address
map<timestamp, text>);

मानचित्र में डेटा सम्मिलित करना

मानचित्र में तत्वों में डेटा सम्मिलित करते समय, सभी दर्ज करें key : value नीचे दिखाए गए अनुसार घुंघराले ब्रेस {} के भीतर कॉमा द्वारा अलग किए गए जोड़े।

cqlsh:tutorialspoint> INSERT INTO data3 (name, address)
   VALUES ('robin', {'home' : 'hyderabad' , 'office' : 'Delhi' } );

एक सेट को अद्यतन करना

निम्न कोड दिखाता है कि डेटा 3 नामक तालिका में मैप डेटा प्रकार को कैसे अपडेट किया जाए। यहां हम मुख्य कार्यालय के मूल्य को बदल रहे हैं, अर्थात्, हम रॉबिन नामक व्यक्ति के कार्यालय के पते को बदल रहे हैं।

cqlsh:tutorialspoint> UPDATE data3
   ... SET address = address+{'office':'mumbai'}
   ... WHERE name = 'robin';

सत्यापन

यदि आप SELECT स्टेटमेंट का उपयोग करके तालिका को सत्यापित करते हैं, तो आपको निम्न परिणाम प्राप्त होंगे -

cqlsh:tutorialspoint> select * from data3;

  name | address
-------+-------------------------------------------
 robin | {'home': 'hyderabad', 'office': 'mumbai'}

(1 rows)