Hive之内置运算符和内置函数

内置运算符

Hive中内置运算符一共有四种:

  • 关系运算符
  • 算术运算符
  • 逻辑运算符
  • 复杂运算符
1、关系运算符
运算符类型描述
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.
2、算术运算符

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

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

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

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

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

内置函数

Hive支持以下内置函数:

返回类型签名描述
BIGINTround(double a)返回BIGINT最近的double值。
BIGINTfloor(double a)返回最大BIGINT值等于或小于double。
BIGINTceil(double a)它返回最小BIGINT值等于或大于double。
doublerand(), rand(int seed)它返回一个随机数,从行改变到行。
stringconcat(string A, string B,…)它返回从A后串联B产生的字符串
stringsubstr(string A, int start, int length)返回从给定长度的起始start位置开始的字符串。
stringupper(string A)它返回从转换的所有字符为大写产生的字符串。
stringucase(string A)它返回从转换的所有字符为大写产生的字符串。
stringlower(string A)它返回转换B的所有字符为小写产生的字符串。
stringlcase(string A)它返回转换B的所有字符为小写产生的字符串。
stringtrim(string A)它返回字符串从A.两端修剪空格的结果
stringltrim(string A)它返回A从一开始修整空格产生的字符串(左手侧)
stringrtrim(string A)rtrim(string A),它返回A从结束修整空格产生的字符串(右侧)
stringregexp_replace(string A, string B, string C)它返回从替换所有子在B结果配合C.在Java正则表达式语法的字符串
intsize(Map<K.V>)它返回在映射类型的元素的数量。
intsize(Array)它返回在数组类型元素的数量。
value of cast( as )它把表达式的结果expr<类型>如cast(‘1’作为BIGINT)代表整体转换为字符串’1’。如果转换不成功,返回的是NULL。
stringfrom_unixtime(int unixtime)转换的秒数从Unix纪元(1970-01-0100:00:00 UTC)代表那一刻,在当前系统时区的时间戳字符的串格式:“1970-01-01 00:00:00”
stringto_date(string timestamp)返回一个字符串时间戳的日期部分:to_date(“1970-01-01 00:00:00”) = “1970-01-01”
intyear(string date)返回年份部分的日期或时间戳字符串:year(“1970-01-01 00:00:00”) = 1970, year(“1970-01-01”) = 1970
intmonth(string date)返回日期或时间戳记字符串月份部分:month(“1970-11-01 00:00:00”) = 11, month(“1970-11-01”) = 11
intday(string date)返回日期或时间戳记字符串当天部分:day(“1970-11-01 00:00:00”) = 1, day(“1970-11-01”) = 1
stringget_json_object(string json_string, string path)提取从基于指定的JSON路径的JSON字符串JSON对象,并返回提取的JSON字符串的JSON对象。如果输入的JSON字符串无效,返回NULL。
内置聚合函数

Hive支持以下内置聚合函数。这些函数的用法类似于SQL聚合函数。

返回类型签名描述
BIGINTcount(*), count(expr),count(*) - 返回检索行的总数。
DOUBLEsum(col), sum(DISTINCT col)返回该组或该组中的列的不同值的分组和所有元素的总和。
DOUBLEavg(col), avg(DISTINCT col)返回上述组或该组中的列的不同值的元素的平均值。
DOUBLEmin(col)返回该组中的列的最小值。
DOUBLEmax(col)返回该组中的列的最大值。
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值