Hive内部表、外部表、分区表介绍

本文介绍了Hive的内部表和外部表的区别,内部表在删除时会删除数据和元数据,而外部表仅删除元数据。此外,还讨论了分区表的概念,它是通过分区列对数据进行粗略划分,提高查询效率,避免全表扫描。创建和加载数据到分区表的示例也进行了展示。
摘要由CSDN通过智能技术生成

如果在创建表时不指定external关键字,则默认的是创建管理表(内部表),内部表对应的目录必须存储在hive的数据仓库中。

create table trade_detail(id bigint, account string, income double, expenses double, time string) row format delimited fields terminated by '\t';

还有一种表是指定external关键字的表,即外部表。
如何创建外部表。

create external table td_ext(id bigint, account string, income double, expenses double, time string) row format delimited fields terminated by '\t' location '/td_ext';

location指定的是hdfs上的目录,该目录表示的是这个外部表目录,这个目录下的文件即为这个表的数据文件。

Hive 创建内部表时,会将数据移动到数据仓库指向的路径;若创建外部表,仅记录数据所在的路径, 
不对数据的位置做任何改变。在删除表的时候,内部表的元数据和数据会被一起删除, 
而外部表只删除元数据,不删除数据。这样外部表相对来说更加安全些,数据组织也更加灵活,方便共享源数据。

下面再举其它例子说说区别

1.内部表:
hive>create table tt (name string , age string);
//此时会在hdfs的/user/hive/warehouse/目录下新建一个tt表的数据存放地
hive>load data inpath '/input/data'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值