कैसेंड्रा - ऑल्टर टेबल

तालिका बदलना

आप कमांड का उपयोग करके तालिका को बदल सकते हैं ALTER TABLE। नीचे दी गई तालिका बनाने के लिए सिंटैक्स है।

वाक्य - विन्यास

ALTER (TABLE | COLUMNFAMILY) <tablename> <instruction>

ALTER कमांड का उपयोग करके, आप निम्नलिखित कार्य कर सकते हैं -

  • एक कॉलम जोड़ें

  • एक कॉलम ड्रॉप करें

एक कॉलम जोड़ना

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

ALTER TABLE table name
ADD  new column datatype;

Example

नीचे दी गई तालिका मौजूदा तालिका में एक कॉलम जोड़ने के लिए एक उदाहरण है। यहां हम एक कॉलम जोड़ रहे हैंemp_email नामित तालिका के लिए पाठ डेटा टाइप करें emp

cqlsh:tutorialspoint> ALTER TABLE emp
   ... ADD emp_email text;

Verification

कॉलम जोड़ा गया है या नहीं, यह सत्यापित करने के लिए सेलेक्ट स्टेटमेंट का उपयोग करें। यहां आप नए जोड़े गए स्तंभ emp_email का निरीक्षण कर सकते हैं।

cqlsh:tutorialspoint> select * from emp;

 emp_id | emp_city | emp_email | emp_name | emp_phone | emp_sal
--------+----------+-----------+----------+-----------+---------

एक स्तंभ को गिराना

ALTER कमांड का उपयोग करके, आप किसी तालिका से एक कॉलम हटा सकते हैं। किसी तालिका से स्तंभ छोड़ने से पहले, जांच लें कि तालिका कॉम्पैक्ट संग्रहण विकल्प से परिभाषित नहीं है। नीचे दिए गए ALTER कमांड का उपयोग करके किसी तालिका से स्तंभ को हटाने के लिए वाक्यविन्यास है।

ALTER table name
DROP column name;

Example

नीचे दी गई एक तालिका से एक स्तंभ को छोड़ने के लिए एक उदाहरण है। यहां हम नाम के कॉलम को हटा रहे हैंemp_email

cqlsh:tutorialspoint> ALTER TABLE emp DROP emp_email;

Verification

सत्यापित करें कि क्या स्तंभ का उपयोग करके हटा दिया गया है select बयान, जैसा कि नीचे दिखाया गया है।

cqlsh:tutorialspoint> select * from emp;

 emp_id | emp_city | emp_name | emp_phone | emp_sal
--------+----------+----------+-----------+---------
(0 rows)

जबसे emp_email स्तंभ हटा दिया गया है, आप इसे अब और नहीं खोज सकते।

जावा एपीआई का उपयोग करके एक टेबल को बदलना

आप सत्र वर्ग के निष्पादन () पद्धति का उपयोग करके एक तालिका बना सकते हैं। जावा एपीआई का उपयोग करके तालिका को बदलने के लिए नीचे दिए गए चरणों का पालन करें।

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 ” );
Session session = cluster.connect(“ tp” );

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

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

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

निम्नलिखित उदाहरण में, हम नाम की तालिका में एक स्तंभ जोड़ रहे हैं emp. ऐसा करने के लिए, आपको क्वेरी को एक स्ट्रिंग चर में संग्रहीत करना होगा और इसे नीचे निष्पादित () विधि में दिखाया गया है।

//Query
String query1 = "ALTER TABLE emp ADD emp_email text";
session.execute(query);

नीचे दिए गए मौजूदा तालिका में एक कॉलम जोड़ने का पूरा कार्यक्रम है।

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

public class Add_column {

   public static void main(String args[]){

      //Query
      String query = "ALTER TABLE emp ADD emp_email text";

      //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("Column added");
   }
}

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

$javac Add_Column.java $java Add_Column

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

Column added

एक कॉलम को हटाना

नीचे दिए गए मौजूदा तालिका से एक कॉलम को हटाने का पूरा कार्यक्रम है।

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

public class Delete_Column {

   public static void main(String args[]){

      //Query
      String query = "ALTER TABLE emp DROP emp_email;";

      //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("Column deleted");
   }
 }

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

$javac Delete_Column.java $java Delete_Column

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

Column deleted