कैसेंड्रा - ऑल्टर टेबल
तालिका बदलना
आप कमांड का उपयोग करके तालिका को बदल सकते हैं 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