如果在创建表时不指定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'

本文介绍了Hive的内部表和外部表的区别,内部表在删除时会删除数据和元数据,而外部表仅删除元数据。此外,还讨论了分区表的概念,它是通过分区列对数据进行粗略划分,提高查询效率,避免全表扫描。创建和加载数据到分区表的示例也进行了展示。
最低0.47元/天 解锁文章
1万+

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



