构建在Hadoop之上的
数据仓库,数据计算使用MR,数据存储使用HDFS
因为数据计算使用mapreduce,因此通常用于进行离线数据处理
Hive 定义了一种类 SQL 查询语言——HQL
类似SQL,但不完全相同
可认为是一个HQL-->MR的语言翻译器。
简单,容易上手
有了Hive,还需要自己写MR程序吗?
Hive的HQL表达的能力有限
迭代式算法无法表达
有些复杂运算用HQL不易表达
Hive
效率较低
Hive自动生成MapReduce作业,通常不够智能;
HQL调优困难,粒度较粗
可控性差
Hive各模块组成
用户接口
包括 CLI,JDBC/ODBC,WebUI
元数据存储(metastore)
默认存储在自带的数据库derby中,线上使用时一般换为MySQL
驱动器(Driver)
解释器、编译器、优化器、执行器
Hadoop

Hive是一个基于Hadoop的数据仓库工具,提供类SQL查询语言HQL,适用于离线数据处理。Hive包括用户接口、元数据存储、驱动器等组件,通过MapReduce进行计算和HDFS存储数据。虽然Hive简化了大数据查询,但其效率较低、HQL表达能力有限且不支持迭代算法。此外,Hive支持分区和桶的概念,以及一些特定的SQL操作,如JOIN和ORDER BY,但不支持UPDATE和非等值JOIN。Hive还允许用户自定义函数来扩展其功能,并有与HBase、Stinger、Shark和Impala等系统的交互和对比。
最低0.47元/天 解锁文章
2081

被折叠的 条评论
为什么被折叠?



