कैसेंड्रा - डेटा पढ़ें

डेटा का चयन करें खण्ड का उपयोग करते हुए पढ़ना

सेसेंड्रा में टेबल से डेटा पढ़ने के लिए सेलेक्ट क्लॉज का उपयोग किया जाता है। इस क्लॉज़ का उपयोग करके, आप एक पूरी तालिका, एक एकल स्तंभ या एक विशेष सेल पढ़ सकते हैं। नीचे दिए गए चयन खंड का वाक्यविन्यास है।

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]]