开发者社区> 问答> 正文

mapjoin中大表和小表可以互换位置吗?

mapjoin中大表和小表可以互换位置吗?

展开
收起
芯在这 2021-12-12 22:06:00 327 0
1 条回答
写回答
取消 提交回答
  • 不可以

    在hive中,(启用Map join时) 大表left join小表,加载从右向左,所以小表会加载进内存,存储成map键值对,通过大表驱动小表,来进行join,即大表中的join字段作为key 来获取value进行join。

    在MySQL中,left join加载从左向右,即join左边的表会先加载进内存,与右边表进行join。

    mapjoin时要让小表进内存,大表进内存的话可能会因为过大的原因,导致mapjoin无法实现,从而转为reduce join。

    MySQL跟hive加载顺序不同。

    最先加载的是驱动表,最好是小表。

    2021-12-12 22:07:08
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载