基本查询
- 全表数据查询:
> select * from testtable;
data:image/s3,"s3://crabby-images/a1a6c/a1a6cff8e824a50a74de658e880d99e131d39f34" alt=""
Hive查询01.png
- 特定列查询:
> select name from testtable;
data:image/s3,"s3://crabby-images/cf010/cf010ddd3a5d8fd9aa8e3019d6dc03a771897497" alt=""
Hive查询02.png
- 语句大小写不敏感,可以全写在一行,也可以写在多行。
- 关键字不能被缩写,也不能分行。
- 使用缩进提高可读性,各子句一般分行写。
- 列别名:
> select name AS nickname from testtable;
data:image/s3,"s3://crabby-images/6885a/6885a695df569761169aa52d8de1b7cbd526c070" alt=""
Hive查询03.png
- 重命名一个列,可以便于计算。
- 写法上可以别名紧跟列名,也可以在列明和别名间使用关键字“AS”,推荐使用关键字写法。
- 算术运算符:
> select age +1 from testtable;
运算符 |
描述 |
A+B |
A加上B |
A-B |
A减去B |
A*B |
A乘以B |
A/B |
A除以B |
A%B |
A对B取余 |
A&B |
A和B按位与 |
A|B |
A和B按位或 |
A^B |
A和B按位异或 |
~A |
A按位取反 |
- 常用函数
> select count(*) name from testtable;
data:image/s3,"s3://crabby-images/aa3db/aa3dbb7a8feb13a88e4405903dddabc74478ffbe" alt=""
Hive查询04.png
> select max(age) max_age from testtable;
data:image/s3,"s3://crabby-images/16ef3/16ef3c59313296754b74cf3dfce4511abe4144d0" alt=""
Hive查询05.png
> select min(age) min_age from testtable;
data:image/s3,"s3://crabby-images/28a07/28a07105687b901c890f21c9c233d8bd5b194598" alt=""
Hive查询06.png
> select sum(age) sum_age from testtable;
data:image/s3,"s3://crabby-images/9c04f/9c04f01464008cf5acf17b569e8ba6520bea6203" alt=""
Hive查询07.png
> select avg(age) avg_age from testtable;
data:image/s3,"s3://crabby-images/72122/7212289082bbff9c4921c4e31c9438b06f2abaa7" alt=""
Hive查询08.png
- Limit限制查询结果返回的行数:
> select * from testtable limit 2;
data:image/s3,"s3://crabby-images/6e845/6e845232a8da50b2cd3667fc2c0aa74be609f47b" alt=""
Hive查询18-limit.png
Where语句
- Where
> select * from testtable where age > 19;
data:image/s3,"s3://crabby-images/88a74/88a743975e25df6dca2c6ff5ae628da9dac1321f" alt=""
Hive查询19-where.png
Where语句过滤不满足条件的结果。
- 比较运算符
操作符 |
支持的数据类型 |
描述 |
A=B |
基本数据类型 |
A等于B返回TRUE,否则返回FALSE |
A<=>B |
基本数据类型 |
若A和B都为NULL,返回TRUE;其他与等号操作符结果一致;若任一为NULL则结果为NULL |
A<>B,A!=B |
基本数据类型 |
A或B为NULL,返回NULL;若A不等于B,返回TRUE,反之返回FALSE |
A<B |
基本数据类型 |
A或B为NULL,返回NULL;若A小于B,返回TRUE,反之返回FALSE |
A<=B |
基本数据类型 |
A或B为NULL,返回NULL;若A小于等于B,返回TRUE,反之返回FALSE |
A>B |
基本数据类型 |
A或B为NULL,返回NULL;若A大于B,返回TRUE,反之返回FALSE |
A>=B |
基本数据类型 |
A或B为NULL,返回NULL;若A大于等于B,返回TRUE,反之返回FALSE |
A [NOT] BETWEEN B AND C |
基本数据类型 |
若A、B或C任一为NULL,返回NULL;若A大于B并小于C,返回TRUE,反之返回FALSE;使用NOT关键字,效果相反 |
A IS NULL |
所有数据类型 |
若A等于NULL,返回TRUE,反之返回FALSE |
A IS NOT NULL |
所有数据类型 |
若A不等于NULL,返回TRUE,反之返回FALSE |
IN[NUM1,NUM2] |
所有数据类型 |
使用IN运算符显示列表中的值 |
A [NOT] LIKE B |
STRING类型 |
B是一个SQL下的简单正则表达式,若A与其匹配的,返回TRUE,反之返回FALSE;B的表达式说明:‘x%’表示A必须以字母‘x’开头,‘%x’表示A必须以字母‘x’结尾,而‘%x%’表示A包含字母‘x’,可以位于开头、结尾或者字符串中间。若使用NOT关键字,效果相反 |
A RLIKE B, A REGEXP B |
STRING类型 |
B是一个正则表达式,若A与其匹配,返回TRUE,反之返回FALSE;匹配使用的是JDK中的正则表达式接口实现的,因为正则也依据其中的规则 |
> select * from testtable where age=20;
data:image/s3,"s3://crabby-images/6730b/6730be937fe38951ed7afb0ac8c7242a258ae261" alt=""
Hive查询09.png
> select * from testtable where age between 15 and 19;
data:image/s3,"s3://crabby-images/7958c/7958c03227aff35a8ab46bef2d88d46b1d898b6d" alt=""
Hive查询10.png
select * from testtable where name is null;
data:image/s3,"s3://crabby-images/def73/def7300d7c653b48fe010b867e6cf535244931a7" alt=""
Hive查询11.png
> select * from testtable where age in (15,20);
data:image/s3,"s3://crabby-images/1ebed/1ebed489765becd010338781ff5668429a72cca1" alt=""
Hive查询12.png
- Like和RLike
查找name中以‘D’开头的名字:
> select * from testtable where name like 'D%';
data:image/s3,"s3://crabby-images/e78fb/e78fb32703a4925e729b0b09f646793c2eb3d626" alt=""
Hive查询13.png
查找name中含有‘D’的名字:
> select * from testtable where name rlike '[D]';
data:image/s3,"s3://crabby-images/5610d/5610da10fff798b0136d33a9d9fabf222e0fd83d" alt=""
Hive查询14.png
- 逻辑运算符
操作符 |
含义 |
AND |
逻辑并 |
OR |
逻辑或 |
NOT |
逻辑否 |
> select * from testtable where name='Snow' and age>18;
data:image/s3,"s3://crabby-images/2452c/2452c203d304d20bffbb636c235f2b98755bd365" alt=""
Hive查询15.png
> select * from testtable where name='Snow' or age>18;
data:image/s3,"s3://crabby-images/8978c/8978cff69632bc29e6c823492868229add8b3adf" alt=""
Hive查询16.png
> select * from testtable where age not in (19,20);
data:image/s3,"s3://crabby-images/535fb/535fb7c5f2a0bda2781aeb1cebc1eb61fec66942" alt=""
Hive查询17.png
网友评论