कैसंड्रा - बैच स्टेटमेंट
बैच विवरण का उपयोग करना
का उपयोग करते हुए 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