hive函数总结---关系运算

关系运算:

  • 等值比较:=

语法:A=B
操作类型:所有基本类型
描述:如果表达式A与表达式B相等,则返回TRUE,否则为FALSE
举例:

hive> SELECT 1 from lxw_dual WHERE 1=1;
1
  • 不等值比较:<>

语法:A<>B
操作类型:所有基本类型
描述:如果表达式A为NULL,或者表达式B为NULL,返回NULL;
如果表达式A与表达式B不相等,则为TRUE,否则为FALSE
举例:

hive>SELECT 1 FROM lxw_dual WHERE 1<>2;
1
  • 小于比较:<

语法:A<B
操作类型:所有基本类型
描述:如果表达式A为NULL,或者表达式B为NULL,返回NULL;
如果表达式A小于表达式B,则为TRUE;否则为FALSE
举例:

hive> SELECT 1 FROM lxw_dual WHERE 1<2;
1
  • 小于等于比较:<=

语法:A<=B
操作类型:所有基本类型
描述:如果表达式A为NULL,或者表达式B为NULL,返回NULL;如果表达式 A 小于或者等于表达式 B,则为 TRUE;否则为 FALSE
举例:

hive> SELECT 1 FROM lxw_dual WHERE 1<=1
1
  • 大于比较

语法:A>B
操作类型:所有基本类型
描述:如果表达式 A 为 NULL,或者表达式 B为 NULL,返回NULL;如果表达式 A 大于表达式 B,则为 TRUE;否则为 FALSE
举例:

hive> SELECT 1 FROM lxw_dual WHERE 2>1;
1
  • 大于等于比较:>=

语法:A>=B
操作类型:所有基本类型
描述:如果表达式 A 为 NULL,或者表达式 B为 NULL,返回NULL;如果表达式 A 大于或者等于表达式 B,则为 TRUE;否则为 FALSE
举例:

hive> SELECT 1 FROM lxw_dual WHERE 1>=1;
1

注意:String 的比较要注意( 常用的时间比较可以先 to_date 之后再比较)

hive> select * from lxw_dual;
OK
2011111209 00:00:00 2011111209
hive> select a,b,a<b,a>b,a=b from lxw_dual;
2011111209 00:00:00 2011111209 false true false
  • 空值判断:IS NULL

语法:A IS NULL
操作类型:所有类型
描述:如果表达式A的值为NULL,则为TRUE,否则为FALSE
举例:

hive> SELECT 1 FROM lxw_dual WHERE NULL IS NULL;
1
  • 非空判断:IS NOT NULL

语法:A IS NOT NULL
操作类型:所有类型
描述:如果表达式A的值为NULL,则为FALSE,否则为TRUE
举例:

hive> SELECT 1 FROM lxw_dual WHERE 1 IS NOT NULL;
1
  • LIKE 比较

语法:A LIKE B
操作类型:strings
描述:如果字符串A或者字符串B为NULL,则返回NULL;
如果字符串A符合表达式B的正则语法,则为TRUE,否则为FALSE;
B中字符"_“表示任意单个字符,字符”%"表示任意数量的字符
举例:

hive> SELECT 1 FROM lxw_dual WHERE 'football' LIKE 'foo%';
1
hive> SELECT 1 FROM lxw_dual WHERE 'football' LIKE 'foot_ _ _ _';
1

注意:否定比较时候用NOT A LIKE B

hive> SELECT 1 FROM lxw_dual WHERE NOT 'football' LIKE 'fff%';
1
  • JAVA的LIKE操作:RLIKE

语法: A RLIKE B
操作类型:strings
描述:如果字符串A或者字符串B为NULL,则返回NULL;
如果字符串A符合JAVA正则表达式B的正则语法,则返回TRUE,否则为FALSE
举例:

hive> SELECT 1 FROM lxw_dual WHERE '123456' RLIKE '^\\d+$';
1
hive> SELECT 1 FROM lxw_dual WHERE '123456aa' RLIKE '^\\d+$';
  • REGEXP 操作

语法:A REGEXP B
操作类型:strings
描述:功能与RLIKE相同
举例:

hive> SELECT 1 FROM lxw_dual WHERE 'footbar' REGEXP '^f.*r$';
1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值