HiveQL - चयन-आदेश द्वारा

यह अध्याय बताता है कि एक सेलेक्ट स्टेटमेंट में ORDER BY क्लॉज का उपयोग कैसे करें। ORDER BY क्लॉज का उपयोग एक कॉलम के आधार पर विवरण प्राप्त करने और आरोही या अवरोही क्रम द्वारा सेट किए गए परिणाम को सॉर्ट करने के लिए किया जाता है।

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

नीचे दिए गए आदेश के आधार पर आदेश का सिंटैक्स है:

SELECT [ALL | DISTINCT] select_expr, select_expr, ... 
FROM table_reference 
[WHERE where_condition] 
[GROUP BY col_list] 
[HAVING having_condition] 
[ORDER BY col_list]] 
[LIMIT number];

उदाहरण

आइए SELECT ... ORDER BY क्लॉज के लिए एक उदाहरण लेते हैं। नीचे दिए गए अनुसार कर्मचारी तालिका मान लीजिए, आईडी, नाम, वेतन, पदनाम और विभाग जैसे क्षेत्रों के साथ। विभाग के नाम का उपयोग करके कर्मचारी विवरण प्राप्त करने के लिए एक क्वेरी उत्पन्न करें।

+------+--------------+-------------+-------------------+--------+
| ID   | Name         | Salary      | Designation       | Dept   |
+------+--------------+-------------+-------------------+--------+
|1201  | Gopal        | 45000       | Technical manager | TP     |
|1202  | Manisha      | 45000       | Proofreader       | PR     |
|1203  | Masthanvali  | 40000       | Technical writer  | TP     |
|1204  | Krian        | 40000       | Hr Admin          | HR     |
|1205  | Kranthi      | 30000       | Op Admin          | Admin  |
+------+--------------+-------------+-------------------+--------+

निम्नलिखित क्वेरी उपरोक्त परिदृश्य का उपयोग करते हुए कर्मचारी विवरण प्राप्त करती है:

hive> SELECT Id, Name, Dept FROM employee ORDER BY DEPT;

क्वेरी के सफल निष्पादन पर, आपको निम्न प्रतिक्रिया देखने को मिलती है:

+------+--------------+-------------+-------------------+--------+
| ID   | Name         | Salary      | Designation       | Dept   |
+------+--------------+-------------+-------------------+--------+
|1205  | Kranthi      | 30000       | Op Admin          | Admin  |
|1204  | Krian        | 40000       | Hr Admin          | HR     |
|1202  | Manisha      | 45000       | Proofreader       | PR     |
|1201  | Gopal        | 45000       | Technical manager | TP     |
|1203  | Masthanvali  | 40000       | Technical writer  | TP     |
+------+--------------+-------------+-------------------+--------+

JDBC कार्यक्रम

यहां दिए गए उदाहरण के लिए ऑर्डर बाय क्लॉज को लागू करने के लिए JDBC प्रोग्राम है।

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

public class HiveQLOrderBy {
   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
      Resultset res = stmt.executeQuery("SELECT * FROM employee ORDER BY DEPT;");
      System.out.println(" ID \t Name \t Salary \t Designation \t Dept ");
      
      while (res.next()) {
         System.out.println(res.getInt(1) + " " + res.getString(2) + " " + res.getDouble(3) + " " + res.getString(4) + " " + res.getString(5));
      }
      
      con.close();
   }
}

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

$ javac HiveQLOrderBy.java
$ java HiveQLOrderBy

आउटपुट:

ID       Name           Salary      Designation          Dept
1205     Kranthi        30000       Op Admin             Admin
1204     Krian          40000       Hr Admin             HR
1202     Manisha        45000       Proofreader          PR
1201     Gopal          45000       Technical manager    TP
1203     Masthanvali    40000       Technical writer     TP
1204     Krian          40000       Hr Admin             HR