1. 程式人生 > >hive函式總結---關係運算

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