hive 显示使用mapjoin

hive> set  hive.auto.convert.join=true;

hive> set  hive.auto.convert.join;
hive.auto.convert.join=true

hive> SELECT 
    -- 可以显示的指定如下这一行mapjoin 关键词。
    /*+mapjoin(b)*/
    a.date,a.page_id,b.page_name,
    count(1) as pv,
    count(distinct gu_id) as uv
    from dw.fct_page_ref a
    left join dw.dim_page b on a.page_id = b.page_id 
    where date = "2017-09-20"
    group by a.date,a.page_id,b.page_name;

执行日志:

Query ID = gongzi_20170922102424_c2e3e956-1c3f-41de-86b6-8531b57a23ab
Total jobs = 1
Execution log at: /tmp/gongzi/gongzi_20170922102424_c2e3e956-1c3f-41de-86b6-8531b57a23ab.log
2017-09-22 10:25:01     Starting to launch local task to process map join;      maximum memory = 1908932608
....
...

MapJoin 使用限制

MapJoin 使用限制,必须是join中从表(子查询)数据比较小。所谓从表,及左外连接的右表,或者右外连接的左表。

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-10-24
  • 2021-08-15
  • 2021-09-20
  • 2022-12-23
  • 2021-09-17
  • 2021-09-13
猜你喜欢
  • 2022-12-23
  • 2021-11-25
  • 2022-02-06
  • 2021-07-03
  • 2021-07-29
  • 2021-08-19
  • 2022-12-23
相关资源
相似解决方案