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 欄位。
廣告