数仓工具—Hive进阶之索引(1)

本文介绍了Hive的索引功能,旨在提高查询速度。详细讲解了索引的机制和原理,创建、查看、删除及重建索引的操作,并强调了使用索引时的配置要求。同时,讨论了索引的优缺点,指出其适用于不频繁更新的静态字段,且Hive 3.0后将移除索引功能。
摘要由CSDN通过智能技术生成

索引

  • Hive从0.7.0版本开始引入了索引,目的是提高Hive表指定列的查询速度。没有索引的时候,Hive在执行查询时需要加载整个表或者整个分区(分区表并提供了相关过滤条件),即使你加了带有谓词的查询(如’WHERE table.column = 10’)依然会加载整个表或分区并处理所有行。但当在指定列上存在索引,再通过指定列查询时,那么只会加载和处理部分文件。在可以预见到分区数据非常庞大的情况下,索引常常是优于分区的。
  • 此外,同传统关系型数据库一样,增加索引在提升查询速度的同时,会额外消耗资源去创建索引和需要更多的磁盘空间存储索引,但是Hive只有有限的索引功能,没有普通关系型数据库中键的概念,而且索引也不会自动更新
  • Hive 0.8.0版本中增加了bitmap索引。

1. 机制和原理

  • Hive的索引其实是一张索引表(Hive的物理表),里面的字段包括:索引列的值、该值对应的 HDFS 文件路径、该值在文件中的偏移量。在查询涉及到索引字段时,首先到索引表查找索引列值对应的 HDFS 文件路径及偏移量,这样就避免了全表扫描。
  • 当Hive通过索引列执行查询时,首先通过一个MRJob去查询索引表,根据索引列的过滤条件࿰
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不二人生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值