Hive 函數以內置運算符

本章介紹Hive的內置運算符。在Hive有四種類型的運算符:正則表達式

  • 關係運算符
  • 算術運算符
  • 邏輯運算符
  • 複雜運算符

關係運算符

這些操做符被用來比較兩個操做數。下表描述了在Hive中可用的關係運算符:數組

運算符 操做 描述
A = B 全部基本類型 若是表達A等於表達B,結果TRUE ,不然FALSE。
A != B 全部基本類型 若是A不等於表達式B表達返回TRUE ,不然FALSE。
A < B 全部基本類型 TRUE,若是表達式A小於表達式B,不然FALSE。
A <= B 全部基本類型 TRUE,若是表達式A小於或等於表達式B,不然FALSE。
A > B 全部基本類型 TRUE,若是表達式A大於表達式B,不然FALSE。
A >= B 全部基本類型 TRUE,若是表達式A大於或等於表達式B,不然FALSE。
A IS NULL 全部類型 TRUE,若是表達式的計算結果爲NULL,不然FALSE。
A IS NOT NULL 全部類型 FALSE,若是表達式A的計算結果爲NULL,不然TRUE。
A LIKE B 字符串 TRUE,若是字符串模式A匹配到B,不然FALSE。
A RLIKE B 字符串 NULL,若是A或B爲NULL;TRUE,若是A任何子字符串匹配Java正則表達式B;不然FALSE。
A REGEXP B 字符串 等同於RLIKE.

示例

讓咱們假設employee表由字段:Id, Name, Salary, Designation, 和Dept組成,以下圖所示。生成一個查詢檢索員工詳細信息 - ID爲1205。spa

+-----+--------------+--------+---------------------------+------+
| 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盧比的僱員的詳細信息。it

hive> SELECT * FROM employee WHERE Salary>=40000;

成功執行的查詢,能看到如下回應:io

+-----+------------+--------+----------------------------+------+
| 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中可用的算術運算符:table

運算符 操做 描述
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。ast

hive> SELECT 20+30 ADD FROM temp;
+--------+
|   ADD  |
+--------+
|   50   |
+--------+

邏輯運算符

運算符是邏輯表達式。全部這些返回TRUE或FALSE。class

運算符 操做 描述
A AND B boolean TRUE,若是A和B都是TRUE,不然FALSE。
A && B boolean 相似於 A AND B.
A OR B boolean TRUE,若是A或B或二者都是TRUE,不然FALSE。
A || B boolean 相似於 A OR B.
NOT A boolean TRUE,若是A是FALSE,不然FALSE。
!A boolean 相似於 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是一個int 它返回數組A的第n個元素,第一個元素的索引0。
M[key] M 是一個 Map<K, V> 並 key 的類型爲K 它返回對應於映射中關鍵字的值。
S.x S 是一個結構 它返回S的s字段
相關文章
相關標籤/搜索