
- 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 - 有用資源
Hive - 內建運算子
本章介紹 Hive 的內建運算子。Hive 中有四種類型的運算子
- 關係運算符
- 算術運算子
- 邏輯運算子
- 複雜運算子
關係運算符
這些運算子用於比較兩個運算元。下表描述了 Hive 中可用的關係運算符
運算子 | 運算元 | 描述 |
---|---|---|
A = B | 所有原始型別 | 如果表示式 A 等於表示式 B,則為 TRUE,否則為 FALSE。 |
A != B | 所有原始型別 | 如果表示式 A 不等於表示式 B,則為 TRUE,否則為 FALSE。 |
A < B | 所有原始型別 | 如果表示式 A 小於表示式 B,則為 TRUE,否則為 FALSE。 |
A <= B | 所有原始型別 | 如果表示式 A 小於或等於表示式 B,則為 TRUE,否則為 FALSE。 |
A > B | 所有原始型別 | 如果表示式 A 大於表示式 B,則為 TRUE,否則為 FALSE。 |
A >= B | 所有原始型別 | 如果表示式 A 大於或等於表示式 B,則為 TRUE,否則為 FALSE。 |
A IS NULL | 所有型別 | 如果表示式 A 計算結果為 NULL,則為 TRUE,否則為 FALSE。 |
A IS NOT NULL | 所有型別 | 如果表示式 A 計算結果為 NULL,則為 FALSE,否則為 TRUE。 |
A LIKE B | 字串 | 如果字串模式 A 與 B 匹配,則為 TRUE,否則為 FALSE。 |
A RLIKE B | 字串 | 如果 A 或 B 為 NULL,則為 NULL;如果 A 的任何子字串與 Java 正則表示式 B 匹配,則為 TRUE,否則為 FALSE。 |
A REGEXP B | 字串 | 與 RLIKE 相同。 |
示例
假設employee表由名為 Id、Name、Salary、Designation 和 Dept 的欄位組成,如下所示。生成一個查詢以檢索 Id 為 1205 的員工詳細資訊。
+-----+--------------+--------+---------------------------+------+ | 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 * FROM employee WHERE Id=1205;
查詢成功執行後,您將看到以下響應
+-----+-----------+-----------+----------------------------------+ | ID | Name | Salary | Designation | Dept | +-----+---------------+-------+----------------------------------+ |1205 | Kranthi | 30000 | Op Admin | Admin | +-----+-----------+-----------+----------------------------------+
執行以下查詢以檢索工資大於或等於 40000 元的員工詳細資訊。
hive> SELECT * FROM employee WHERE Salary>=40000;
查詢成功執行後,您將看到以下響應
+-----+------------+--------+----------------------------+------+ | 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 | +-----+------------+--------+----------------------------+------+
算術運算子
這些運算子支援運算元的各種常見算術運算。它們都返回數字型別。下表描述了 Hive 中可用的算術運算子
運算子 | 運算元 | 描述 |
---|---|---|
A + B | 所有數字型別 | 給出 A 和 B 相加的結果。 |
A - B | 所有數字型別 | 給出從 A 中減去 B 的結果。 |
A * B | 所有數字型別 | 給出 A 和 B 相乘的結果。 |
A / B | 所有數字型別 | 給出從 A 中除以 B 的結果。 |
A % B | 所有數字型別 | 給出 A 除以 B 產生的餘數。 |
A & B | 所有數字型別 | 給出 A 和 B 按位與的結果。 |
A | B | 所有數字型別 | 給出 A 和 B 按位或的結果。 |
A ^ B | 所有數字型別 | 給出 A 和 B 按位異或的結果。 |
~A | 所有數字型別 | 給出 A 按位非的結果。 |
示例
以下查詢將兩個數字 20 和 30 相加。
hive> SELECT 20+30 ADD FROM temp;
查詢成功執行後,您將看到以下響應
+--------+ | ADD | +--------+ | 50 | +--------+
邏輯運算子
運算子是邏輯表示式。它們都返回 TRUE 或 FALSE。
運算子 | 運算元 | 描述 |
---|---|---|
A AND B | 布林值 | 如果 A 和 B 都為 TRUE,則為 TRUE,否則為 FALSE。 |
A && B | 布林值 | 與 A AND B 相同。 |
A OR B | 布林值 | 如果 A 或 B 或兩者都為 TRUE,則為 TRUE,否則為 FALSE。 |
A || B | 布林值 | 與 A OR B 相同。 |
NOT A | 布林值 | 如果 A 為 FALSE,則為 TRUE,否則為 FALSE。 |
!A | 布林值 | 與 NOT A 相同。 |
示例
以下查詢用於檢索部門為 TP 且工資大於 40000 元的員工詳細資訊。
hive> SELECT * FROM employee WHERE Salary>40000 && Dept=TP;
查詢成功執行後,您將看到以下響應
+------+--------------+-------------+-------------------+--------+ | ID | Name | Salary | Designation | Dept | +------+--------------+-------------+-------------------+--------+ |1201 | Gopal | 45000 | Technical manager | TP | +------+--------------+-------------+-------------------+--------+
複雜運算子
這些運算子提供了一個表示式來訪問複雜型別的元素。
運算子 | 運算元 | 描述 |
---|---|---|
A[n] | A 是一個數組,n 是一個整數 | 它返回陣列 A 中的第 n 個元素。第一個元素的索引為 0。 |
M[key] | M 是一個 Map<K, V>,key 的型別為 K | 它返回對映中對應於鍵的值。 |
S.x | S 是一個結構體 | 它返回 S 的 x 欄位。 |
廣告