- Hive 教程
- Hive - 首頁
- Hive - 介紹
- Hive - 安裝
- Hive - 資料型別
- Hive - 建立資料庫
- Hive - 刪除資料庫
- Hive - 建立表
- Hive - 修改表
- Hive - 刪除表
- Hive - 分割槽
- Hive - 內建運算子
- Hive - 內建函式
- Hive - 檢視和索引
- HiveQL
- HiveQL - Select Where
- HiveQL - Select Order By
- HiveQL - Select Group By
- HiveQL - Select Joins
- Hive 實用資源
- Hive - 常見問題解答
- Hive - 快速指南
- Hive - 實用資源
HiveQL - Select-Group By
本章解釋了 SELECT 語句中 GROUP BY 子句的詳細資訊。GROUP BY 子句用於使用特定收集列對結果集中的所有記錄進行分組。它用於查詢一組記錄。
語法
GROUP 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…GROUP BY 子句的示例。假設 employee 表如下所示,包含 Id、姓名、工資、職位和部門欄位。生成一個查詢以檢索每個部門的員工人數。
+------+--------------+-------------+-------------------+--------+ | ID | Name | Salary | Designation | Dept | +------+--------------+-------------+-------------------+--------+ |1201 | Gopal | 45000 | Technical manager | TP | |1202 | Manisha | 45000 | Proofreader | PR | |1203 | Masthanvali | 40000 | Technical writer | TP | |1204 | Krian | 45000 | Proofreader | PR | |1205 | Kranthi | 30000 | Op Admin | Admin | +------+--------------+-------------+-------------------+--------+
以下查詢使用上述場景檢索員工詳細資訊。
hive> SELECT Dept,count(*) FROM employee GROUP BY DEPT;
成功執行查詢後,你將看到以下響應
+------+--------------+ | Dept | Count(*) | +------+--------------+ |Admin | 1 | |PR | 2 | |TP | 3 | +------+--------------+
JDBC 程式
下面給出了應用於給定示例的 Group By 子句的 JDBC 程式。
import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.DriverManager;
public class HiveQLGroupBy {
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://:10000/userdb", "", "");
// create statement
Statement stmt = con.createStatement();
// execute statement
Resultset res = stmt.executeQuery(“SELECT Dept,count(*) ” + “FROM employee GROUP BY DEPT; ”);
System.out.println(" Dept \t count(*)");
while (res.next()) {
System.out.println(res.getString(1) + " " + res.getInt(2));
}
con.close();
}
}
將程式儲存在名為 HiveQLGroupBy.java 的檔案中。使用以下命令編譯並執行此程式。
$ javac HiveQLGroupBy.java $ java HiveQLGroupBy
輸出
Dept Count(*) Admin 1 PR 2 TP 3
廣告