本章介紹Hive的內(nèi)置運(yùn)算符。在Hive有四種類型的運(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 | +-----+------------+--------+----------------------------+------+
這些運(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)算符是邏輯表達(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 | +------+--------------+-------------+-------------------+--------+
這些運(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字段 |
更多建議: