कैसेंड्रा - डेटा हटाएं

एक तालिका 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