कैसेंड्रा - डेटा पढ़ें
डेटा का चयन करें खण्ड का उपयोग करते हुए पढ़ना
सेसेंड्रा में टेबल से डेटा पढ़ने के लिए सेलेक्ट क्लॉज का उपयोग किया जाता है। इस क्लॉज़ का उपयोग करके, आप एक पूरी तालिका, एक एकल स्तंभ या एक विशेष सेल पढ़ सकते हैं। नीचे दिए गए चयन खंड का वाक्यविन्यास है।
SELECT FROM <tablename>
उदाहरण
मान लें कि नाम के कीस्पेस में एक टेबल है emp निम्नलिखित विवरण के साथ -
emp_id | emp_name | emp_city | emp_phone | emp_sal |
---|---|---|---|---|
1 | राम | हैदराबाद | 9848022338 | 50000 |
2 | रोबिन | शून्य | 9848022339 | 50000 |
3 | रहमान | चेन्नई | 9848022330 | 50000 |
4 | राजीव | पुणे | 9848022331 | 30000 |
निम्न उदाहरण से पता चलता है कि SELECT क्लॉज का उपयोग करके पूरी तालिका कैसे पढ़ें। यहाँ हम एक सारणी पढ़ रहे हैं जिसे कहा जाता हैemp।
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)
आवश्यक कॉलम पढ़ना
निम्न उदाहरण दिखाता है कि किसी तालिका में किसी विशेष कॉलम को कैसे पढ़ा जाए।
cqlsh:tutorialspoint> SELECT emp_name, emp_sal from emp;
emp_name | emp_sal
----------+---------
ram | 50000
robin | 50000
rajeev | 30000
rahman | 50000
(4 rows)
कहां कारण
जहां क्लॉज का उपयोग करते हुए, आप आवश्यक कॉलम पर एक बाधा डाल सकते हैं। इसका सिंटैक्स इस प्रकार है -
SELECT FROM <table name> WHERE <condition>;
Note - WHERE क्लॉज का उपयोग केवल उन कॉलम पर किया जा सकता है जो प्राथमिक कुंजी का एक हिस्सा हैं या उन पर एक द्वितीयक सूचकांक है।
निम्नलिखित उदाहरण में, हम एक ऐसे कर्मचारी का विवरण पढ़ रहे हैं, जिसका वेतन 50000 है। सबसे पहले, स्तंभ emp_al पर द्वितीयक सूचकांक सेट करें।
cqlsh:tutorialspoint> CREATE INDEX ON emp(emp_sal);
cqlsh:tutorialspoint> SELECT * FROM emp WHERE emp_sal=50000;
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
जावा एपीआई का उपयोग करते हुए डेटा पढ़ना
आप सत्र वर्ग के निष्पादन () पद्धति का उपयोग करके तालिका से डेटा पढ़ सकते हैं। जावा एपीआई की मदद से बैच स्टेटमेंट का उपयोग करके कई कथनों को निष्पादित करने के लिए नीचे दिए गए चरणों का पालन करें।
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तालिका। क्वेरी को एक स्ट्रिंग में संग्रहीत करें और सत्र कक्षा के निष्पादन () विधि में इसे नीचे दिखाए अनुसार पास करें।
String query = ”SELECT 8 FROM emp”;
session.execute(query);
सत्र वर्ग के निष्पादन () विधि का उपयोग करके क्वेरी निष्पादित करें।
चरण 4: परिणाम ऑब्जेक्ट प्राप्त करें
चयनित क्वेरी परिणाम के रूप में वापस आ जाएगी ResultSet ऑब्जेक्ट, इसलिए परिणाम को ऑब्जेक्ट में स्टोर करें RESULTSET नीचे दिखाया गया है।
ResultSet result = session.execute( );
नीचे एक तालिका से डेटा पढ़ने का पूरा कार्यक्रम दिया गया है।
import com.datastax.driver.core.Cluster;
import com.datastax.driver.core.ResultSet;
import com.datastax.driver.core.Session;
public class Read_Data {
public static void main(String args[])throws Exception{
//queries
String query = "SELECT * FROM emp";
//Creating Cluster object
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
//Creating Session object
Session session = cluster.connect("tutorialspoint");
//Getting the ResultSet
ResultSet result = session.execute(query);
System.out.println(result.all());
}
}
उपरोक्त प्रोग्राम को .java के बाद वाले वर्ग नाम से सहेजें, उस स्थान पर ब्राउज़ करें जहाँ इसे सहेजा गया है। नीचे दिखाए अनुसार कार्यक्रम को संकलित और निष्पादित करें।
$javac Read_Data.java
$java Read_Data
सामान्य परिस्थितियों में, इसे निम्न आउटपुट का उत्पादन करना चाहिए -
[Row[1, Hyderabad, ram, 9848022338, 50000], Row[2, Delhi, robin,
9848022339, 50000], Row[4, Pune, rajeev, 9848022331, 30000], Row[3,
Chennai, rahman, 9848022330, 50000]]