欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-03-08 09:42:57
...

关系运算:

  • 等值比较:=

语法: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
相关标签: hive