2.6 Hive内置运算符

2016-03-17 23:42:30 5,696 0

在Hive有四种类型的运算符:

  • 关系运算符

  • 算术运算符

  • 逻辑运算符

  • 复杂运算符

以下列出的操作符(operators)和函数(functions)可能不是最新的。可以在Beeline或者Hive CLI交互窗口中,使用以下命令来查看最新的文档。

SHOW FUNCTIONS;
DESCRIBE FUNCTION <function_name>;
DESCRIBE FUNCTION EXTENDED <function_name>;


关系操作符(Relational Operators)

以下操作符比较操作数(operands)从而产生TRUE/FALSE值。


运算符操作数描述
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。关系型数据库中的like功能。
A RLIKE B字符串NULL,如果A或B为NULL;TRUE,如果A任何子字符串匹配Java正则表达式B;否则FALSE。
A REGEXP B字符串等同于RLIKE.



算数运算符

这些运算符支持的操作数各种常见的算术运算。所有这些返回数字类型。下表描述了在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按位非的结果


逻辑运算符

运算符是逻辑表达式。所有这些返回TRUE或FALSE。

运算符操作描述
A AND BbooleanTRUE,如果A和B都是TRUE,否则FALSE。
A && Bboolean类似于 A AND B.
A OR BbooleanTRUE,如果A或B或两者都是TRUE,否则FALSE。
A || Bboolean类似于 A OR B.
NOT AbooleanTRUE,如果A是FALSE,否则FALSE。
!Aboolean类似于 NOT A.


复杂的运算符

这些运算符提供一个表达式来接入复杂类型的元素。

运算符操作描述
A[n]A是一个数组,n是一个int它返回数组A的第n个元素,第一个元素的索引0。
M[key]M 是一个 Map<K, V> 并 key 的类型为K它返回对应于映射中关键字的值。
S.xS 是一个结构它返回S的s字段