Hive 內(nèi)置運(yùn)算符

2021-09-29 10:07 更新

本章介紹Hive的內(nèi)置運(yùn)算符。在Hive有四種類型的運(yùn)算符:

  • 關(guān)系運(yùn)算符
  • 算術(shù)運(yùn)算符
  • 邏輯運(yùn)算符
  • 復(fù)雜運(yùn)算符

關(guān)系運(yùn)算符

這些操作符被用來比較兩個(gè)操作數(shù)。下表描述了在Hive中可用的關(guān)系運(yùn)算符:

運(yùn)算符 操作 描述
A = B 所有基本類型 如果表達(dá)A等于表達(dá)B,結(jié)果TRUE ,否則FALSE。
A != B 所有基本類型 如果A不等于表達(dá)式B表達(dá)返回TRUE ,否則FALSE。
A < B 所有基本類型 TRUE,如果表達(dá)式A小于表達(dá)式B,否則FALSE。
A <= B 所有基本類型 TRUE,如果表達(dá)式A小于或等于表達(dá)式B,否則FALSE。
A > B 所有基本類型 TRUE,如果表達(dá)式A大于表達(dá)式B,否則FALSE。
A >= B 所有基本類型 TRUE,如果表達(dá)式A大于或等于表達(dá)式B,否則FALSE。
A IS NULL 所有類型 TRUE,如果表達(dá)式的計(jì)算結(jié)果為NULL,否則FALSE。
A IS NOT NULL 所有類型 FALSE,如果表達(dá)式A的計(jì)算結(jié)果為NULL,否則TRUE。
A LIKE B 字符串 TRUE,如果字符串模式A匹配到B,否則FALSE。
A RLIKE B 字符串 NULL,如果A或B為NULL;TRUE,如果A任何子字符串匹配Java正則表達(dá)式B;否則FALSE。
A REGEXP B 字符串 等同于RLIKE.

示例

讓我們假設(shè)employee表由字段:Id, Name, Salary, Designation, 和Dept組成,如下圖所示。生成一個(gè)查詢檢索員工詳細(xì)信息 - 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|
+-----+--------------+--------+---------------------------+------+

以下查詢執(zhí)行檢索使用上述表中的雇員的詳細(xì)信息:

hive> SELECT * FROM employee WHERE Id=1205;

成功執(zhí)行的查詢,能看到以下回應(yīng):

+-----+-----------+-----------+----------------------------------+
| ID  | Name      | Salary    | Designation              | Dept  |
+-----+---------------+-------+----------------------------------+
|1205 | Kranthi   | 30000     | Op Admin                 | Admin |
+-----+-----------+-----------+----------------------------------+

下面的查詢執(zhí)行以檢索薪水大于或等于40000盧比的雇員的詳細(xì)信息。

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

成功執(zhí)行的查詢,能看到以下回應(yīng):

+-----+------------+--------+----------------------------+------+
| 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   |
+-----+------------+--------+----------------------------+------+

算術(shù)運(yùn)算符

這些運(yùn)算符支持的操作數(shù)各種常見的算術(shù)運(yùn)算。所有這些返回?cái)?shù)字類型。下表描述了在Hive中可用的算術(shù)運(yùn)算符:

運(yùn)算符 操作 描述
A + B 所有數(shù)字類型 A加B的結(jié)果
A - B 所有數(shù)字類型 A減去B的結(jié)果
A * B 所有數(shù)字類型 A乘以B的結(jié)果
A / B 所有數(shù)字類型 A除以B的結(jié)果
A % B 所有數(shù)字類型 A除以B.產(chǎn)生的余數(shù)
A & B 所有數(shù)字類型 A和B的按位與結(jié)果
A | B 所有數(shù)字類型 A和B的按位或結(jié)果
A ^ B 所有數(shù)字類型 A和B的按位異或結(jié)果
~A 所有數(shù)字類型 A按位非的結(jié)果

示例

下面的查詢相加兩個(gè)數(shù)字,20和30。

hive> SELECT 20+30 ADD FROM temp;

在成功執(zhí)行查詢后,能看到以下回應(yīng):

+--------+
|   ADD  |
+--------+
|   50   |
+--------+

邏輯運(yùn)算符

運(yùn)算符是邏輯表達(dá)式。所有這些返回TRUE或FALSE。

運(yùn)算符 操作 描述
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盧比的員工詳細(xì)信息。

hive> SELECT * FROM employee WHERE Salary>40000 && Dept=TP;

成功執(zhí)行查詢后,能看到以下回應(yīng):

+------+--------------+-------------+-------------------+--------+
| ID   | Name         | Salary      | Designation       | Dept   |
+------+--------------+-------------+-------------------+--------+
|1201  | Gopal        | 45000       | Technical manager | TP     |
+------+--------------+-------------+-------------------+--------+

復(fù)雜的運(yùn)算符

這些運(yùn)算符提供一個(gè)表達(dá)式來接入復(fù)雜類型的元素。

運(yùn)算符 操作 描述
A[n] A是一個(gè)數(shù)組,n是一個(gè)int 它返回?cái)?shù)組A的第n個(gè)元素,第一個(gè)元素的索引0。
M[key] M 是一個(gè) Map<K, V> 并 key 的類型為K 它返回對(duì)應(yīng)于映射中關(guān)鍵字的值。
S.x S 是一個(gè)結(jié)構(gòu) 它返回S的s字段


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)