कैसेंड्रा - डेटा हटाएं
एक तालिका Datafrom हटाना
आप कमांड का उपयोग करके तालिका से डेटा हटा सकते हैं DELETE। इसका सिंटैक्स इस प्रकार है -
DELETE FROM <identifier> WHERE <condition>;
उदाहरण
मान लेते हैं कि कैसंड्रा में एक टेबल है जिसे कहा जाता है emp निम्नलिखित डेटा होने -
emp_id | emp_name | emp_city | emp_phone | emp_sal |
---|---|---|---|---|
1 | राम | हैदराबाद | 9848022338 | 50000 |
2 | रोबिन | हैदराबाद | 9848022339 | 40000 |
3 | रहमान | चेन्नई | 9848022330 | 45,000 |
निम्नलिखित कथन अंतिम पंक्ति के emp_sal कॉलम को हटा देता है -
cqlsh:tutorialspoint> DELETE emp_sal FROM emp WHERE emp_id=3;
सत्यापन
यह सत्यापित करने के लिए कि डेटा हटा दिया गया है या नहीं, SELECT स्टेटमेंट का उपयोग करें। यदि आप SELECT का उपयोग कर एम्पायर टेबल को सत्यापित करते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
cqlsh:tutorialspoint> select * from emp;
emp_id | emp_city | emp_name | emp_phone | emp_sal
--------+-----------+----------+------------+---------
1 | Hyderabad | ram | 9848022338 | 50000
2 | Delhi | robin | 9848022339 | 50000
3 | Chennai | rahman | 9848022330 | null
(3 rows)
चूंकि हमने रहमान का वेतन हटा दिया है, आप वेतन के स्थान पर एक शून्य मान देखेंगे।
संपूर्ण पंक्ति हटाना
निम्न आदेश एक तालिका से पूरी पंक्ति हटाता है।
cqlsh:tutorialspoint> DELETE FROM emp WHERE emp_id=3;
सत्यापन
यह सत्यापित करने के लिए कि डेटा हटा दिया गया है या नहीं, SELECT स्टेटमेंट का उपयोग करें। यदि आप SELECT का उपयोग कर एम्पायर टेबल को सत्यापित करते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
cqlsh:tutorialspoint> select * from emp;
emp_id | emp_city | emp_name | emp_phone | emp_sal
--------+-----------+----------+------------+---------
1 | Hyderabad | ram | 9848022338 | 50000
2 | Delhi | robin | 9848022339 | 50000
(2 rows)
चूंकि हमने पिछली पंक्ति को हटा दिया है, इसलिए तालिका में केवल दो पंक्तियाँ शेष हैं।
जावा एपीआई का उपयोग करके डेटा हटाना
आप सत्र वर्ग के निष्पादन () पद्धति का उपयोग करके किसी तालिका में डेटा हटा सकते हैं। जावा एपीआई का उपयोग करके तालिका से डेटा हटाने के लिए नीचे दिए गए चरणों का पालन करें।
Step1: एक क्लस्टर ऑब्जेक्ट बनाएँ
का एक उदाहरण बनाएँ Cluster.builder की कक्षा com.datastax.driver.core पैकेज के रूप में नीचे दिखाया गया है।
//Creating Cluster.Builder object
Cluster.Builder builder1 = Cluster.builder();
का उपयोग करके एक संपर्क बिंदु (नोड का आईपी पता) जोड़ें addContactPoint() उसकि विधि Cluster.Builderवस्तु। यह विधि लौटती हैCluster.Builder।
//Adding contact point to the Cluster.Builder object
Cluster.Builder builder2 = build.addContactPoint( "127.0.0.1" );
नए बिल्डर ऑब्जेक्ट का उपयोग करके, क्लस्टर ऑब्जेक्ट बनाएँ। ऐसा करने के लिए, आपके पास एक विधि हैbuild() में Cluster.Builderकक्षा। क्लस्टर ऑब्जेक्ट बनाने के लिए निम्न कोड का उपयोग करें।
//Building a cluster
Cluster cluster = builder.build();
आप नीचे दिखाए गए अनुसार कोड की एक लाइन का उपयोग करके क्लस्टर ऑब्जेक्ट का निर्माण कर सकते हैं।
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
चरण 2: एक सत्र वस्तु बनाएँ
नीचे दिखाए गए अनुसार क्लस्टर वर्ग के कनेक्ट () पद्धति का उपयोग करके सत्र वस्तु का एक उदाहरण बनाएं।
Session session = cluster.connect();
यह विधि एक नया सत्र बनाती है और इसे आरंभ करती है। यदि आपके पास पहले से ही एक कीस्पेस है, तो आप इसे नीचे दिखाए गए अनुसार स्ट्रिंग विधि में कीस्पेस नाम से पास करके इसे मौजूदा एक पर सेट कर सकते हैं।
Session session = cluster.connect(“ Your keyspace name ”);
यहाँ हम KeySpace नामक का उपयोग कर रहे हैं tp। इसलिए, नीचे दिखाए अनुसार सत्र ऑब्जेक्ट बनाएं।
Session session = cluster.connect(“tp”);
चरण 3: क्वेरी को निष्पादित करें
आप सत्र वर्ग के निष्पादन () विधि का उपयोग करके CQL प्रश्नों को निष्पादित कर सकते हैं। क्वेरी को स्ट्रिंग प्रारूप में या निष्पादन क्लास () विधि के लिए स्टेटमेंट क्लास ऑब्जेक्ट के रूप में पास करें। आप स्ट्रिंग प्रारूप में इस पद्धति से जो भी पास करेंगे, उस पर अमल किया जाएगाcqlsh।
निम्नलिखित उदाहरण में, हम नाम की तालिका से डेटा हटा रहे हैं emp. आपको क्वेरी को एक स्ट्रिंग चर में संग्रहीत करना होगा और इसे पास करना होगा execute() नीचे दिखाए अनुसार विधि।
String query1 = ”DELETE FROM emp WHERE emp_id=3; ”;
session.execute(query);
नीचे दिए गए जावा एपीआई का उपयोग करके कैसंड्रा में एक मेज से डेटा को हटाने का पूरा कार्यक्रम है।
import com.datastax.driver.core.Cluster;
import com.datastax.driver.core.Session;
public class Delete_Data {
public static void main(String args[]){
//query
String query = "DELETE FROM emp WHERE emp_id=3;";
//Creating Cluster object
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
//Creating Session object
Session session = cluster.connect("tp");
//Executing the query
session.execute(query);
System.out.println("Data deleted");
}
}
उपरोक्त प्रोग्राम को .java के बाद वाले वर्ग नाम से सहेजें, उस स्थान पर ब्राउज़ करें जहाँ इसे सहेजा गया है। नीचे दिखाए अनुसार कार्यक्रम को संकलित और निष्पादित करें।
$javac Delete_Data.java
$java Delete_Data
सामान्य परिस्थितियों में, इसे निम्न आउटपुट का उत्पादन करना चाहिए -
Data deleted