हाइव - ऑल्टर टेबल

यह अध्याय बताता है कि तालिका की विशेषताओं को कैसे बदला जाए जैसे कि इसका तालिका नाम बदलना, स्तंभ नाम बदलना, स्तंभ जोड़ना और स्तंभों को हटाना या प्रतिस्थापित करना।

ऑल्टर टेबल स्टेटमेंट

इसका उपयोग हाइव में एक टेबल को बदलने के लिए किया जाता है।

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

एक तालिका में संशोधित करने के लिए हम क्या विशेषताएँ चाहते हैं, इसके आधार पर कथन निम्न में से कोई भी वाक्यविन्यास लेता है।

ALTER TABLE name RENAME TO new_name
ALTER TABLE name ADD COLUMNS (col_spec[, col_spec ...])
ALTER TABLE name DROP [COLUMN] column_name
ALTER TABLE name CHANGE column_name new_name new_type
ALTER TABLE name REPLACE COLUMNS (col_spec[, col_spec ...])

नाम बदलें ... कथन

निम्न क्वेरी से तालिका का नाम बदल देता है employee सेवा emp

hive> ALTER TABLE employee RENAME TO emp;

JDBC कार्यक्रम

एक तालिका का नाम बदलने के लिए JDBC कार्यक्रम इस प्रकार है।

import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet; 
import java.sql.Statement;
import java.sql.DriverManager;

public class HiveAlterRenameTo {
   private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
   
   public static void main(String[] args) throws SQLException {
   
      // Register driver and create driver instance
      Class.forName(driverName);
      
      // get connection
      Connection con = DriverManager.getConnection("jdbc:hive://localhost:10000/userdb", "", "");
      
      // create statement
      Statement stmt = con.createStatement();
      
      // execute statement
      stmt.executeQuery("ALTER TABLE employee RENAME TO emp;");
      System.out.println("Table Renamed Successfully");
      con.close();
   }
}

प्रोग्राम को HiveAlterRenameTo.java नामक फ़ाइल में सहेजें। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग करें।

$ javac HiveAlterRenameTo.java
$ java HiveAlterRenameTo

आउटपुट:

Table renamed successfully.

बयान बदलें

निम्न तालिका में फ़ील्ड हैं employee तालिका और यह फ़ील्ड को बोल्ड करने के लिए दिखाता है (बोल्ड में)।

कार्यक्षेत्र नाम डेटा प्रकार से कनवर्ट करें फ़ील्ड नाम बदलें डेटा प्रकार में कनवर्ट करें
ईद पूर्णांक ईद पूर्णांक
name तार ename तार
वेतन Float वेतन Double
पद तार पद तार

उपरोक्त डेटा का उपयोग करके निम्नलिखित क्वेरीज़ कॉलम नाम और कॉलम डेटा प्रकार का नाम बदल देती है:

hive> ALTER TABLE employee CHANGE name ename String;
hive> ALTER TABLE employee CHANGE salary salary Double;

JDBC कार्यक्रम

नीचे दिए गए कॉलम को बदलने के लिए JDBC प्रोग्राम है।

import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.DriverManager;

public class HiveAlterChangeColumn {
   private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
   
   public static void main(String[] args) throws SQLException {
   
      // Register driver and create driver instance
      Class.forName(driverName);
      
      // get connection
      Connection con = DriverManager.getConnection("jdbc:hive://localhost:10000/userdb", "", "");
      
      // create statement
      Statement stmt = con.createStatement();
      
      // execute statement
      stmt.executeQuery("ALTER TABLE employee CHANGE name ename String;");
      stmt.executeQuery("ALTER TABLE employee CHANGE salary salary Double;");
      
      System.out.println("Change column successful.");
      con.close();
   }
}

प्रोग्राम को HiveAlterChangeColumn.java नामक फ़ाइल में सहेजें। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग करें।

$ javac HiveAlterChangeColumn.java
$ java HiveAlterChangeColumn

आउटपुट:

Change column successful.

कॉलम स्टेटमेंट जोड़ें

निम्न क्वेरी कर्मचारी तालिका के लिए एक स्तंभ को विभाग तालिका में जोड़ती है।

hive> ALTER TABLE employee ADD COLUMNS ( 
dept STRING COMMENT 'Department name');

JDBC कार्यक्रम

एक तालिका में एक स्तंभ जोड़ने के लिए JDBC कार्यक्रम नीचे दिया गया है।

import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.DriverManager;

public class HiveAlterAddColumn {
   private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
   
   public static void main(String[] args) throws SQLException {
   
      // Register driver and create driver instance
      Class.forName(driverName);

      // get connection
      Connection con = DriverManager.getConnection("jdbc:hive://localhost:10000/userdb", "", "");

      // create statement
      Statement stmt = con.createStatement();
      
      // execute statement
      stmt.executeQuery("ALTER TABLE employee ADD COLUMNS " + " (dept STRING COMMENT 'Department name');");
      System.out.prinln("Add column successful.");
      
      con.close();
   }
}

प्रोग्राम को HiveAlterAddColumn.java नामक फ़ाइल में सहेजें। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग करें।

$ javac HiveAlterAddColumn.java
$ java HiveAlterAddColumn

आउटपुट:

Add column successful.

स्टेटमेंट बदलें

निम्न क्वेरी से सभी स्तंभों को हटा देता है employee तालिका और इसके साथ प्रतिस्थापित करती है emp तथा name कॉलम:

hive> ALTER TABLE employee REPLACE COLUMNS ( 
eid INT empid Int, 
ename STRING name String);

JDBC कार्यक्रम

नीचे दिए गए JDBC को बदलने का कार्यक्रम है eid के साथ कॉलम empid तथा ename के साथ कॉलम name

import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.DriverManager;

public class HiveAlterReplaceColumn {

   private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
   
   public static void main(String[] args) throws SQLException {
   
      // Register driver and create driver instance
      Class.forName(driverName);
      
      // get connection
      Connection con = DriverManager.getConnection("jdbc:hive://localhost:10000/userdb", "", "");
      
      // create statement
      Statement stmt = con.createStatement();
      
      // execute statement
      stmt.executeQuery("ALTER TABLE employee REPLACE COLUMNS "
         +" (eid INT empid Int,"
         +" ename STRING name String);");
         
      System.out.println(" Replace column successful");
      con.close();
   }
}

प्रोग्राम को HiveAlterReplaceColumn.java नामक फ़ाइल में सहेजें। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग करें।

$ javac HiveAlterReplaceColumn.java
$ java HiveAlterReplaceColumn

आउटपुट:

Replace column successful.