- HCatalog 教程
- HCatalog - 首页
- HCatalog - 简介
- HCatalog - 安装
- HCatalog - CLI
- HCatalog CLI 命令
- HCatalog - 创建表
- HCatalog - 修改表
- HCatalog - 视图
- HCatalog - 显示表
- HCatalog - 显示分区
- HCatalog - 索引
- HCatalog API
- HCatalog - 读写器
- HCatalog - 输入输出格式
- HCatalog - 加载器和存储器
- HCatalog 有用资源
- HCatalog - 快速指南
- HCatalog - 有用资源
- HCatalog - 讨论
HCatalog - 显示分区
分区是用于表格数据的条件,用于创建单独的表或视图。SHOW PARTITIONS 列出了给定基本表的所有现有分区。分区按字母顺序排列。在 Hive 0.6 之后,还可以指定分区规范的一部分来过滤结果列表。
您可以使用 SHOW PARTITIONS 命令查看特定表中存在的分区。本章介绍如何在 HCatalog 中列出特定表的partitions。
Show Partitions 语句
语法如下:
SHOW PARTITIONS table_name;
以下查询删除名为 employee 的表:
./hcat –e "Show partitions employee;"
查询成功执行后,您将看到以下响应:
OK Designation = IT Time taken: 5.3 seconds
动态分区
HCatalog 将表组织成分区。这是一种根据分区列(如日期、城市和部门)的值将表划分为相关部分的方法。使用分区,可以轻松查询数据的一部分。
例如,名为 Tab1 的表包含员工数据,如 id、name、dept 和 yoj(即加入年份)。假设您需要检索 2012 年加入的所有员工的详细信息。查询将搜索整个表以获取所需信息。但是,如果您使用年份对员工数据进行分区并将其存储在单独的文件中,则可以减少查询处理时间。以下示例显示如何对文件及其数据进行分区:
以下文件包含 employeedata 表。
/tab1/employeedata/file1
id, name, dept, yoj 1, gopal, TP, 2012 2, kiran, HR, 2012 3, kaleel, SC, 2013 4, Prasanth, SC, 2013
以上数据使用年份划分为两个文件。
/tab1/employeedata/2012/file2
1, gopal, TP, 2012 2, kiran, HR, 2012
/tab1/employeedata/2013/file3
3, kaleel, SC, 2013 4, Prasanth, SC, 2013
添加分区
我们可以通过更改表来向表添加分区。假设我们有一个名为 employee 的表,其字段如 Id、Name、Salary、Designation、Dept 和 yoj。
语法
ALTER TABLE table_name ADD [IF NOT EXISTS] PARTITION partition_spec [LOCATION 'location1'] partition_spec [LOCATION 'location2'] ...; partition_spec: : (p_column = p_col_value, p_column = p_col_value, ...)
以下查询用于向 employee 表添加分区。
./hcat –e "ALTER TABLE employee ADD PARTITION (year = '2013') location '/2012/part2012';"
重命名分区
您可以使用 RENAME-TO 命令重命名分区。其语法如下:
./hact –e "ALTER TABLE table_name PARTITION partition_spec RENAME TO PARTITION partition_spec;"
以下查询用于重命名分区:
./hcat –e "ALTER TABLE employee PARTITION (year=’1203’) RENAME TO PARTITION (Yoj='1203');"
删除分区
用于删除分区的命令的语法如下:
./hcat –e "ALTER TABLE table_name DROP [IF EXISTS] PARTITION partition_spec,. PARTITION partition_spec,...;"
以下查询用于删除分区:
./hcat –e "ALTER TABLE employee DROP [IF EXISTS] PARTITION (year=’1203’);"
广告