黑马程序员-大数据入门到实战-分布式SQL计算 Hive 语法与概念

简介: 黑马程序员-大数据入门到实战-分布式SQL计算 Hive 语法与概念

1. 数据库操作

  • 创建数据库
create database if not exists myhive;
  • 查看数据库详细信息
desc database myhive;
  • 数据库本质上就是在HDFS之上的文件夹
  • 默认数据库的存放路径是HDFS的:/user/hive/warehouse内
  • 创建数据库并指定hdfs存储位置
create database myhive2 location '/myhive2';
  • 删除一个空数据库
drop  database  myhive;
  • 强制删除数据库
drop  database  myhive2  cascade;

2. 数据表操作

2.1 表操作语法和数据类型

2.2 内部表操作

  1. 内部表和外部表

内部表(CREATE TABLE table_name …)

未被external关键字修饰的即是内部表, 即普通表。 内部表又称管理表,内部表数据存储的位置由hive.metastore.warehouse.dir参数决定(默认:/user/hive/warehouse),删除内部表会直接删除元数据(metadata)及存储数据,因此内部表不适合和其他工具共享数据。

外部表(CREATE EXTERNAL TABLE table_name …LOCATION…)

被external关键字修饰的即是外部表, 即关联表。

外部表是指表数据可以在任何位置,通过LOCATION关键字指定。 数据存储的不同也代表了这个表在理念是并不是Hive内部管理的,而是可以随意临时链接到外部数据上的。

  1. 内部表和外部表对比

  2. 创建内部表
  • 创建表
create table table_name……
  • 查看表的数据
  1. 自定义指定分隔符
create table if not exists stu2(id int ,name string) row format delimited fields terminated by '\t';
  1. 删除内部表
drop table table_name

2.3 外部表操作

  1. 创建外部表语法
  • create external table ……
  • 必须使用row format delimited fields terminated by指定列分隔符
  • 必须使用location指定数据路径
  1. 外部表和其数据相互独立
  • 可以先有表后有数据
  • 也可以先有数据,后有表
  • 表和数据只是一个链接关系
  • 所以删除表,表不存在了但数据保留。
  1. 内外部表转换
  • 内转外:stu set tblproperties(‘EXTERNAL’=‘TRUE’)
  • 外转内:stu set tblproperties(‘EXTERNAL’=‘FALSE’)

2.4 数据加载和导出

  1. 外部表是临时使用的,重要数据建议存入内部表进行管理
  2. 加载数据的语法
  • load data [local] inpath ‘filepath’ [overwrite] into table tablename;
  • insert into | overwrite select ……
  1. 注意事项
  • 数据来源本地,本地数据会保留,本质是本地文件上传到HDFS
  • 数据来自HDFS,加载后文件不存在,本质是在HDFS上进行文件移动
  1. Hive数据导出的方式
  • insert [local] select
  • bin/hive -e ‘SQL’ > file
  • bin/hive -f ‘sql file’ > file

2.5 分区表

  1. 分区表的定义
  • 可以选择字段作为表分区
  • 分区其实就是HDFS上的不同文件夹
  • 分区表可以极大的提高特定场景下Hive的操作性能
  1. 分区表的语法
  • create table tablename(…) partitioned by (分区列 列类型)
  • 分区表的分区列,在partitioned by中定义,不在普通列中定义

2.6 分桶表

  1. 分桶表定义
  • 可以选择字段作为分桶字段
  • 分桶表本质上是数据分开在不同的文件中
  • 分区和分桶可以同时使用
  1. 分桶表的语法
  • 通过clustered by(c_id) into 3 buckets
  • clustered by 指定分桶字段
  • into num buckets指定分桶数量
  1. 分桶表能带来什么性能提升
  • 单值过滤
  • JOIN
  • GROUP BY

2.7 修改表

  • 表重命名
alter  table  old_table_name  rename  to  new_table_name;
  • 修改表属性值
ALTER TABLE table_name SET TBLPROPERTIES table_properties;
  • 添加分区
ALTER TABLE tablename  ADD PARTITION (month='201101');
  • 修改分区值
ALTER TABLE tablename PARTITION (month='202005') RENAME TO PARTITION (month='201105');
  • 删除分区
ALTER TABLE tablename DROP PARTITION (month='201105');
  • 添加列
ALTER TABLE table_name ADD COLUMNS (v1 int, v2 string);
  • 修改列名
ALTER TABLE test_change CHANGE v1 v1new INT;
  • 删除表
DROP TABLE tablename;
  • 清空表
TRUNCATE TABLE tablename;

2.8 复杂类型操作

2.8.1 Array数组

  1. array类型,主要存储数组格式
  2. 定义格式
  • array<类型>
  • 数组元素之间的分隔符:collection items terminated by ‘分隔符’
  1. 在查询中使用
  • 数组[数字序号],可以取出指定需要元素
  • size(数组),可以统计数组元素个数
  • array contains(数组,数据),可以查看指定数据是否在数组中存在

2.8.2 Map映射

  1. map类型,主要存储:K-V键值对类型数据
  2. 定义格式
  • map<key类型,value类型>
  • 不同键值对之间:collection items terminated by ‘分隔符’
  • 一个键值对内:map keys terminated by ‘分隔符’
  1. 在查询中使用
  • map[key]来获取指定key的值
  • map_keys(map)取到全部的key作为array返回,map_values(map)取到全部的values
  • size(map)可以统计K-V对的个数

array_contains(map_values(map),数据)可以统计map是否包含指定数据

2.8.3 Struct结构

struct类型,主要存储:复合格式

定义格式

structname:string,age:int

struct的分隔符只需要:collection items terminated by ‘分隔符’

  1. 在查询中使用
  • struct.key即可取得对应的value

3. 数据查询

3.1 基本查询

Hive中使用基本查询SELECT、WHERE、GROUP BY、聚合函数、HAVING、JOIN和普通的SQL语句没有区别

3.2 RLIKE 正则匹配

可以基于正则表达式,对数据内容进行匹配

3.3 UNION联合

  • 将多个SELECT的结果集合并成一个
  • 多个SELECT的结果集需要架构一致
  • 自带去重效果,如无需去重,使用UNION ALL 即可

3.4 Sampling采样

桶抽样方式:tablesample(bucket x out of y on (colname | rand()))

块抽样方式:tablesample(num rows | num percent | num(K|M|G))

3.5 Virtual Columns虚拟列

  1. 虚拟列
  • INPUT__FILE__NAME,显示数据行所在的具体文件
  • BLOCK__OFFSET__INSIDE__FILE,显示数据行所在文件的偏移量
  • ROW__OFFSET__INSIDE__BLOCK,显示数据所在HDFS块的偏移量(此虚拟列需要设置:SET hive.exec.rowoffset=true )才可使用
  1. 作用
  • 查看行级别的数据详细参数
  • 可以用于where、group by等
  • 可以协助进行错误排查工作

4. 函数

5. 案例

相关实践学习
基于MaxCompute的热门话题分析
Apsara Clouder大数据专项技能认证配套课程:基于MaxCompute的热门话题分析
目录
相关文章
|
6月前
|
算法 NoSQL 关系型数据库
《聊聊分布式》分布式系统核心概念
分布式系统由多节点协同工作,突破单机瓶颈,提升可用性与扩展性。CAP定理指出一致性、可用性、分区容错性三者不可兼得,BASE理论通过基本可用、软状态、最终一致性实现工程平衡,共识算法如Raft保障数据一致与系统可靠。
|
7月前
|
存储 算法 安全
“卧槽,系统又崩了!”——别慌,这也许是你看过最通俗易懂的分布式入门
本文深入解析分布式系统核心机制:数据分片与冗余副本实现扩展与高可用,租约、多数派及Gossip协议保障一致性与容错。探讨节点故障、网络延迟等挑战,揭示CFT/BFT容错原理,剖析规模与性能关系,为构建可靠分布式系统提供理论支撑。
336 2
|
11月前
|
SQL 分布式计算 大数据
大数据新视界 --大数据大厂之Hive与大数据融合:构建强大数据仓库实战指南
本文深入介绍 Hive 与大数据融合构建强大数据仓库的实战指南。涵盖 Hive 简介、优势、安装配置、数据处理、性能优化及安全管理等内容,并通过互联网广告和物流行业案例分析,展示其实际应用。具有专业性、可操作性和参考价值。
大数据新视界 --大数据大厂之Hive与大数据融合:构建强大数据仓库实战指南
|
9月前
|
数据采集 分布式计算 大数据
不会Python,还敢说搞大数据?一文带你入门大数据编程的“硬核”真相
不会Python,还敢说搞大数据?一文带你入门大数据编程的“硬核”真相
194 1
|
8月前
|
SQL 分布式计算 大数据
SparkSQL 入门指南:小白也能懂的大数据 SQL 处理神器
在大数据处理的领域,SparkSQL 是一种非常强大的工具,它可以让开发人员以 SQL 的方式处理和查询大规模数据集。SparkSQL 集成了 SQL 查询引擎和 Spark 的分布式计算引擎,使得我们可以在分布式环境下执行 SQL 查询,并能利用 Spark 的强大计算能力进行数据分析。
|
数据采集 数据可视化 大数据
Python入门修炼:开启你在大数据世界的第一个脚本
Python入门修炼:开启你在大数据世界的第一个脚本
230 6
|
SQL 分布式计算 资源调度
Dataphin功能Tips系列(48)-如何根据Hive SQL/Spark SQL的任务优先级指定YARN资源队列
如何根据Hive SQL/Spark SQL的任务优先级指定YARN资源队列
460 4
|
消息中间件 关系型数据库 Java
‘分布式事务‘ 圣经:从入门到精通,架构师尼恩最新、最全详解 (50+图文4万字全面总结 )
本文 是 基于尼恩之前写的一篇 分布式事务的文章 升级而来 , 尼恩之前写的 分布式事务的文章, 在全网阅读量 100万次以上 , 被很多培训机构 作为 顶级教程。 此文修改了 老版本的 一个大bug , 大家不要再看老版本啦。
|
SQL 分布式计算 Hadoop
Hadoop-12-Hive 基本介绍 下载安装配置 MariaDB安装 3台云服务Hadoop集群 架构图 对比SQL HQL
Hadoop-12-Hive 基本介绍 下载安装配置 MariaDB安装 3台云服务Hadoop集群 架构图 对比SQL HQL
362 3
|
Dubbo Java 应用服务中间件
分布式-dubbo的入门
分布式-dubbo的入门