Hive笔记-5

240619-Hive笔记-5

6.2.2 全表和特定列查询

1) 全表查询
sql 复制代码
hive (default)> select * from emp;

select 查看你要查看的信息

from 你要从哪张表里面查

2) 选择特定列查询
sql 复制代码
hive (default)> select empno, ename from emp;

注意:

(1)SQL 语言大小写不敏感。

(2)SQL 可以写在一行或者多行。

(3)关键字不能被缩写也不能分行。

(4)各子句一般要分行写。

(5)使用缩进提高语句的可读性。

查看 empno 和 ename 列

6.2.3 列别名

重命名一个列

便于计算

紧跟列名,也可以在列名和别名之间加入关键字'AS'

案例实操

查询名称和部门。

sql 复制代码
hive (default)> 

select 

    ename AS name,

    deptno dn

from emp;

as 可以省略

6.2.4 Limit 语句

典型的查询会返回多行数据。limit子句用于限制返回的行数。

sql 复制代码
hive (default)> select * from emp limit 5;

hive (default)> select * from emp limit 2,3; -- 表示从第2行开始,向下抓取3行

返回前五个数据:

6.2.5 Where 语句

使用 where 子句, 将不满足条件的行过滤掉

where 子句紧随from子句

案例实操

  • 1000的所有员工。
sql 复制代码
hive (default)> select * from emp where sal > 1000;

注意:where子句中不能使用字段别名。

6.2.6 关系运算函数

1) 基本语法

如下操作符主要用于where和having语句中。

|---------------------------|
| *操作符* |
| A=B |
| A<=>B |
| A<>B, A!=B |
| A<B |
| A<=B |
| A>B |
| A>=B |
| A not between B and C |
| A is null |
| A is not null |
| in(数值1,数值2) |
| A not like B |
| A rlike B, A regexp B |

查询工资在500~1000的员工:

查找研发岗和销售岗的员工:

sql 复制代码
select empno as emp_id ename emp_name from emp where job in('研发','销售')

job 是列名,不是语法

查找所有姓张.的:

sql 复制代码
select * from emp where ename like "张%"

%表示匹配一个字符

like 模糊匹配

匹配不是姓张的:

6.2.7 逻辑运算函数

找日志(本地模式):

/tmp/用户名/hive.log

命令:

tail -500 /tmp/用户名/hive.log

1) 基本语法 (and/or/not)

|-------------|
| 操作符 |
| and |
| or |
| not |

2) 案例实操
(1) 查询薪水大于1000,部门是30
sql 复制代码
hive (default)> 

select 

    * 

from emp

where sal > 1000 and deptno = 30;
(2) 查询薪水大于1000,或者部门是30
sql 复制代码
hive (default)> 

select 

    * 

from emp

where sal>1000 or deptno=30;
(3) 查询除了20部门和30部门以外的员工信息
sql 复制代码
hive (default)> 

select 

    * 

from emp

where deptno not in(30, 20);
相关推荐
foundbug9992 分钟前
最优化问题的外点罚函数法与内点罚函数法-MATLAB实现
开发语言·matlab
键盘上的猫头鹰2 分钟前
【Linux 基础教程(一)】概述、安装与网络配置:VMware + CentOS + NAT + XShell 远程连接
linux·网络·centos
弹简特4 分钟前
【零基础学Python】05-Python函数完全指南:从初阶定义到进阶参数,一篇打通核心难点
开发语言·python
枳实-叶8 分钟前
【Linux驱动开发】第18天:I2C驱动深度解析
linux·运维·驱动开发
AugustRed9 分钟前
A2UI 完整学习指南(含 Java 后端 + 前端实战示例)
java·开发语言·前端
shandianchengzi12 分钟前
【记录】Ubuntu|Ubuntu 26.04 笔记本耗电过快,排查 省电过程
linux·运维·ubuntu
王莎莎-MinerU13 分钟前
Agent 时代,科学数据 API 需要重新设计
大数据·前端·数据库·人工智能·个人开发
jingling55517 分钟前
自建技术博客实战(三):工具专栏——地图定位、声音复刻与 rembg 抠图
android·开发语言·前端·ai·nextjs
不做无法实现的梦~17 分钟前
Git Clone 使用 Watt/Steam++ 加速时报证书错误的原因与解决方法
大数据·git·elasticsearch
智塑未来18 分钟前
如何选择RFID软硬件系统供应商:采购决策的关键判断维度
大数据·人工智能