कैसंड्रा - बैच स्टेटमेंट

बैच विवरण का उपयोग करना

का उपयोग करते हुए BATCH,आप एक साथ कई संशोधन विवरण (सम्मिलित करें, अद्यतन, हटाएं) निष्पादित कर सकते हैं। इसका सिंटैक्स इस प्रकार है -

BEGIN BATCH
<insert-stmt>/ <update-stmt>/ <delete-stmt>
APPLY BATCH

उदाहरण

मान लें कि कैसंड्रा में एक तालिका है जिसे निम्नलिखित डेटा कहा जाता है -

emp_id emp_name emp_city emp_phone emp_sal
1 राम हैदराबाद 9848022338 50000
2 रोबिन दिल्ली 9848022339 50000
3 रहमान चेन्नई 9848022330 45,000

इस उदाहरण में, हम निम्नलिखित ऑपरेशन करेंगे -

  • निम्नलिखित विवरण (4, rajeev, pune, 9848022331, 30000) के साथ एक नई पंक्ति डालें।
  • पंक्ति आईडी 3 से 50000 के साथ कर्मचारी का वेतन अपडेट करें।
  • पंक्ति आईडी 2 के साथ कर्मचारी का शहर हटाएं।

उपरोक्त कार्यों को एक बार में करने के लिए, निम्नलिखित बैट कमांड का उपयोग करें -

cqlsh:tutorialspoint> BEGIN BATCH
... INSERT INTO emp (emp_id, emp_city, emp_name, emp_phone, emp_sal) values(  4,'Pune','rajeev',9848022331, 30000);
... UPDATE emp SET emp_sal = 50000 WHERE emp_id =3;
... DELETE emp_city FROM emp WHERE emp_id = 2;
... APPLY BATCH;

सत्यापन

परिवर्तन करने के बाद, SELECT स्टेटमेंट का उपयोग करके तालिका को सत्यापित करें। यह निम्नलिखित उत्पादन का उत्पादन करना चाहिए -

cqlsh:tutorialspoint> select * from emp;

 emp_id |  emp_city | emp_name |  emp_phone | emp_sal
--------+-----------+----------+------------+---------
      1 | Hyderabad | ram      | 9848022338 | 50000
      2 | null      | robin    | 9848022339 | 50000
      3 | Chennai   | rahman   | 9848022330 | 50000
      4 | Pune      | rajeev   | 9848022331 | 30000
    
(4 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 ”);

यहां हम नाम के कीस्पेस का उपयोग कर रहे हैं tp। इसलिए, नीचे दिखाए अनुसार सत्र ऑब्जेक्ट बनाएं।

Session session = cluster.connect(“tp”);

चरण 3: क्वेरी को निष्पादित करें

आप सत्र वर्ग के निष्पादन () विधि का उपयोग करके CQL प्रश्नों को निष्पादित कर सकते हैं। क्वेरी को स्ट्रिंग प्रारूप में या निष्पादन क्लास () विधि के लिए स्टेटमेंट क्लास ऑब्जेक्ट के रूप में पास करें। आप स्ट्रिंग प्रारूप में इस पद्धति से जो भी पास करेंगे, उस पर अमल किया जाएगाcqlsh

इस उदाहरण में, हम निम्नलिखित ऑपरेशन करेंगे -

  • निम्नलिखित विवरण (4, rajeev, pune, 9848022331, 30000) के साथ एक नई पंक्ति डालें।
  • पंक्ति आईडी 3 से 50000 के साथ कर्मचारी का वेतन अपडेट करें।
  • पंक्ति आईडी 2 के साथ कर्मचारी का शहर हटाएं।

आपको क्वेरी को एक स्ट्रिंग चर में संग्रहीत करना होगा और इसे नीचे निष्पादित () विधि में दिखाया गया है।

String query1 = ” BEGIN BATCH INSERT INTO emp (emp_id, emp_city, emp_name,   emp_phone, emp_sal) values( 4,'Pune','rajeev',9848022331, 30000);
UPDATE emp SET emp_sal = 50000 WHERE emp_id =3;
DELETE emp_city FROM emp WHERE emp_id = 2;
APPLY BATCH;”;

नीचे दिए गए जावा एपीआई का उपयोग करके कैसंड्रा में एक मेज पर एक साथ कई बयानों को निष्पादित करने का पूरा कार्यक्रम है।

import com.datastax.driver.core.Cluster;
import com.datastax.driver.core.Session;

public class Batch {

   public static void main(String args[]){
    
      //query
      String query =" BEGIN BATCH INSERT INTO emp (emp_id, emp_city,
         emp_name, emp_phone, emp_sal) values( 4,'Pune','rajeev',9848022331, 30000);"
    
         + "UPDATE emp SET emp_sal = 50000 WHERE emp_id =3;"
         + "DELETE emp_city FROM emp WHERE emp_id = 2;"
         + "APPLY BATCH;";

      //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("Changes done");
   }
}

उपरोक्त प्रोग्राम को .java के बाद वाले वर्ग नाम से सहेजें, उस स्थान पर ब्राउज़ करें जहाँ इसे सहेजा गया है। नीचे दिखाए अनुसार कार्यक्रम को संकलित और निष्पादित करें।

$javac Batch.java $java Batch

सामान्य परिस्थितियों में, इसे निम्न आउटपुट का उत्पादन करना चाहिए -

Changes done