Fork me on GitHub

Hive表的索引

目录

  • 背景
  • 第一部分 Spark内存管理详解
  • 第二部分 Spark参数说明
  • 第三部分 Spark内存优化
  • 第四部分 常见线上问题解决
  • 参考文献及资料

背景

简介

Hive从0.7.0版本开始加入了索引,

在 0.7.0 版中添加了 Hive 索引,在 0.8.0 版中添加了位图索引。

索引已在 3.0 版(HIVE-18448)中被“删除”。

https://issues.apache.org/jira/browse/HIVE-18448

目的是提高Hive表指定列的查询速度。没有索引的时候,Hive在执行查询时需要加载整个表或者整个分区,然后处理所有的数据,但当在指定列上存在索引,再通过指定列查询时,那么只会加载和处理部分文件。此外,同传统关系型数据库一样,增加索引在提升查询速度的同时,会额外消耗资源去创建索引和需要更多的磁盘空间存储索引。

机制和原理

Hive的索引其实是一张索引表(Hive的物理表),在表里面存储索引列的值,该值对应的HDFS的文件路径,该值在数据文件中的偏移量。
当Hive通过索引列执行查询时,首先通过一个MR Job去查询索引表,根据索引列的过滤条件,查询出该索引列值对应的HDFS文件目录及偏移量,并且把这些数据输出到HDFS的一个文件中,然后再根据这个文件中去筛选原文件,作为查询Job的输入。

优点

  • 可以避免全表扫描和资源浪费
  • 可以加快含有group by的语句的查询速度

创建索引

1
2
3
4
create index test_index on table test(id)
as 'org.apache.hadoop.hive.ql.index.compact.CompactIndexHandler'
with deferred rebuild
in table test;

生成索引数据

刚创建完的Hive索引表是没有数据的,需要生成索引数据

1
alter index test_index on test rebuild;

使用索引

1
2
3
SET hive.input.format=org.apache.hadoop.hive.ql.io.HiveInputFormat;
SET hive.optimize.index.filter=true;
SET hive.optimize.index.filter.compact.minsize=0;

删除索引

1
drop index test_index on test;

缺点

  • 使用过程繁琐
  • 需用额外Job扫描索引表
  • 不会自动刷新,如果表有数据变动,索引表需要手动刷新

参考文献及资料

1、数据治理对运维数据体系的思考与启发,链接:http://blog.itpub.net/69994525/viewspace-2762789/

本文标题:Hive表的索引

文章作者:rong xiang

发布时间:2022年01月20日 - 13:01

最后更新:2022年10月25日 - 23:10

原始链接:https://zjrongxiang.github.io/posts/b218f1c7/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

0%