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