Hive优化

本文介绍了优化Hive查询性能的多种策略,包括设置`hive.fetch.task.conversion`为`more`以减少MR任务,启用MapJoin以处理小表,调整join操作的表顺序,处理null键,避免笛卡尔积,选择性查询列,使用数据分区和压缩,以及通过Explain查看执行计划来分析和优化。这些技巧有助于提升大数据查询效率。
摘要由CSDN通过智能技术生成

1.Fetch抓取设置为more

hive-default.xml.template文件中hive.fetch.task.conversion默认是more老版本hive默认是minimal。设置为more后,全局查找、字段查找、limit等都不走MR。

2.开启Map join

如果不指定map join或者不符合map join的条件,hive会将数据发送到reduce端进行join,容易发生数据倾斜。可以用map join把小表加载到内存中在map端进行join,避免reduce端join。

开启map join:

  • 首先设置自动选择map join(默认已开启)
    set hive.auto.convert.join = true;
  • 设置小表阈值(默认25M以下是小表)
    set hive.mapjoin.smalltable.filesize=25000000;

3.小表在左,大表在右

key相对分散,数据量小的表放在join左边。hive3中已经做了优化,大表小表哪个在左都可以。

4.重复数据较多的表在左

重复数据较多的表放在join左边。

5.过滤为null的key再连接

所有为null的key都会进入同一个reduce,产生数据倾斜。

6.空key转换

如果key为null的数据不想舍弃,可以给是null的key加随机数。

7.避免笛卡尔积

join时指定on连接条件,避免产生笛卡尔积。

8.尽可能不写select *

只查询需要的列。

9.数据分区或分桶存储

10.数据压缩

压缩数据降低IO。

11.Explain查看执行计划

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值