Hive-索引

作者: 风筝flying | 来源:发表于2018-11-02 16:47 被阅读4次

简介

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

机制和原理

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

优点

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

创建索引

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

生成索引数据

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

alter index test_index on test rebuild;

使用索引

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;

删除索引

drop index test_index on test;

缺点

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

相关文章

  • Hive-索引

    简介 Hive从0.7.0版本开始加入了索引,目的是提高Hive表指定列的查询速度。没有索引的时候,Hive在执行...

  • Hive-索引

    Hive 索引 由Lefty Leverenz创建,最后修改于六月17,2018 从3.0开始删除索引 Hive索...

  • 数仓--Hive--面试题准备

    数仓--Hive-面试之Hive与HBase的区别数仓--Hive-面试之Hive架构原理数仓--Hive-面试之...

  • hsql优化

    HSQL 转载:https://www.fangxuan.win/2018/08/09/hive-%E6%80%A...

  • Apache Hive - 通用调优

    Apache Hive-通用优化-featch抓取机制 mr本地模式 Fetch抓取机制 功能:在执行sql的时...

  • hive-函数

    1、建表导入json数据 建表:create table rating_json(json string); 导入...

  • hive-入门

    hive脚本执行: hive建表语句: 创建一个文件并上传到hdfs: 查看表中的数据: 以上创建的表都是内部表,...

  • HIVE- 数据倾斜

    数据倾斜就是由于数据分布不均匀,数据大量集中到一点上,造成数据热点。大多数情况下,分为一下三种情况: 1.map端...

  • Hive-函数汇总

    [toc] 关系运算 1、等值比较: = 语法:A=B操作类型:所有基本类型描述: 如果表达式A与表达式B相等,则...

  • Hive-初识HIVE(一)

    转载自:https://www.cnblogs.com/qingyunzong/p/8707885.html Hi...

网友评论

    本文标题:Hive-索引

    本文链接:https://www.haomeiwen.com/subject/myjcxqtx.html