赞
踩
Hive中内置运算符一共有四种:
运算符 | 类型 | 描述 |
---|---|---|
A=B | 所有基本类型 | 如果表达A等于表达B,结果TRUE ,否则FALSE。 |
A != B | 所有基本类型 | 如果A不等于表达式B表达返回TRUE ,否则FALSE。 |
A < B | 所有基本类型 | 如果表达式A小于表达式B返回TRUE,否则FALSE。 |
A <= B | 所有基本类型 | 如果表达式A小于或等于表达式B返回TRUE,否则FALSE。 |
A > B | 所有基本类型 | 如果表达式A大于表达式B返回TRUE,否则FALSE。 |
A >= B | 所有基本类型 | 如果表达式A大于或等于表达式B返回TRUE,否则FALSE。 |
A IS NULL | 所有类型 | 如果表达式的计算结果为NULL返回TRUE,否则FALSE。 |
A IS NOT NULL | 所有类型 | 如果表达式的计算结果为NULL返回TRUE,否则FALSE。 |
A LIKE B | 字符串 | 如果字符串模式A匹配到B返回TRUE,否则FALSE。 |
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 l B | 所有数字类型 | A和B的按位或结果 |
A ^ B | 所有数字类型 | A和B的按位异或结果 |
~A | 所有数字类型 | A按位非的结果 |
运算符是逻辑表达式。所有这些返回TRUE或FALSE。
运算符 | 操作 | 描述 |
---|---|---|
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 ll B | boolean | 类似于 A OR B. |
NOT A | boolean | TRUE,如果A是FALSE,否则FALSE。 |
!A | boolean | 类似于 NOT A. |
这些运算符提供一个表达式来接入复杂类型的元素。
运算符 | 操作 | 描述 |
---|---|---|
A[n] | A是一个数组,n是一个int | 它返回数组A的第n个元素,第一个元素的索引0。 |
M[key] | M 是一个 Map<K, V> 并 key 的类型为K | 它返回对应于映射中关键字的值。 |
S.x | S 是一个结构 | 它返回S的s字段 |
Hive支持以下内置函数:
返回类型 | 签名 | 描述 |
---|---|---|
BIGINT | round(double a) | 返回BIGINT最近的double值。 |
BIGINT | floor(double a) | 返回最大BIGINT值等于或小于double。 |
BIGINT | ceil(double a) | 它返回最小BIGINT值等于或大于double。 |
double | rand(), rand(int seed) | 它返回一个随机数,从行改变到行。 |
string | concat(string A, string B,…) | 它返回从A后串联B产生的字符串 |
string | substr(string A, int start, int length) | 返回从给定长度的起始start位置开始的字符串。 |
string | upper(string A) | 它返回从转换的所有字符为大写产生的字符串。 |
string | ucase(string A) | 它返回从转换的所有字符为大写产生的字符串。 |
string | lower(string A) | 它返回转换B的所有字符为小写产生的字符串。 |
string | lcase(string A) | 它返回转换B的所有字符为小写产生的字符串。 |
string | trim(string A) | 它返回字符串从A.两端修剪空格的结果 |
string | ltrim(string A) | 它返回A从一开始修整空格产生的字符串(左手侧) |
string | rtrim(string A) | rtrim(string A),它返回A从结束修整空格产生的字符串(右侧) |
string | regexp_replace(string A, string B, string C) | 它返回从替换所有子在B结果配合C.在Java正则表达式语法的字符串 |
int | size(Map<K.V>) | 它返回在映射类型的元素的数量。 |
int | size(Array) | 它返回在数组类型元素的数量。 |
value of | cast( as ) | 它把表达式的结果expr<类型>如cast(‘1’作为BIGINT)代表整体转换为字符串’1’。如果转换不成功,返回的是NULL。 |
string | from_unixtime(int unixtime) | 转换的秒数从Unix纪元(1970-01-0100:00:00 UTC)代表那一刻,在当前系统时区的时间戳字符的串格式:“1970-01-01 00:00:00” |
string | to_date(string timestamp) | 返回一个字符串时间戳的日期部分:to_date(“1970-01-01 00:00:00”) = “1970-01-01” |
int | year(string date) | 返回年份部分的日期或时间戳字符串:year(“1970-01-01 00:00:00”) = 1970, year(“1970-01-01”) = 1970 |
int | month(string date) | 返回日期或时间戳记字符串月份部分:month(“1970-11-01 00:00:00”) = 11, month(“1970-11-01”) = 11 |
int | day(string date) | 返回日期或时间戳记字符串当天部分:day(“1970-11-01 00:00:00”) = 1, day(“1970-11-01”) = 1 |
string | get_json_object(string json_string, string path) | 提取从基于指定的JSON路径的JSON字符串JSON对象,并返回提取的JSON字符串的JSON对象。如果输入的JSON字符串无效,返回NULL。 |
Hive支持以下内置聚合函数。这些函数的用法类似于SQL聚合函数。
返回类型 | 签名 | 描述 |
---|---|---|
BIGINT | count(*), count(expr), | count(*) - 返回检索行的总数。 |
DOUBLE | sum(col), sum(DISTINCT col) | 返回该组或该组中的列的不同值的分组和所有元素的总和。 |
DOUBLE | avg(col), avg(DISTINCT col) | 返回上述组或该组中的列的不同值的元素的平均值。 |
DOUBLE | min(col) | 返回该组中的列的最小值。 |
DOUBLE | max(col) | 返回该组中的列的最大值。 |
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。