本章介紹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字段 |