Hive中的内部表与外部表

Hive中内部表与外部表的区别: 

1)创建表时:创建内部表时,会将数据移动到数据仓库指向的路径;若创建外部表,仅记录数据所在的路径, 不对数据的位置做任何改变。
2)删除表时:在删除表的时候,内部表的元数据和数据会被一起删除, 而外部表只删除元数据,不删除数据。这样外部表相对来说更加安全些,数据组织也更加灵活,方便共享源数据。
创建内部表的方法:
create table inner_table(id bigint)
stored as ORC
location '......';
LOAD DATA
INPATH '/....../inner_table/20170901'
OVERWRITE INTO TABLE inner_table
partition(ptDate='20170901');

创建外部表的方法:

create EXTERNAL table IF NOT EXISTS outer_table
stored as ORC
location '......';

 

 

 

 

posted @ 2017-09-06 21:52  大仁哥spark  阅读(591)  评论(0)    收藏  举报