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