Hive DDL

1.创建内部表

create table person1(
id int,
name string,
likes ARRAY <string>,
address MAP <string,string>
)
ROW FORMAT DELIMITED
//指定每一项分割
FIELDS TERMINATED BY ','
//指定集合分割
COLLECTION ITEMS TERMINATED BY '_'
//指定Map分割
MAP KEYS TERMINATED BY ':';

2.数据及其格式如下

load_data.txt
1,xiaoming,book-tv-code,beijing:chaoyan-chsnaghai:pudong
2,lilei,book-code,lioaning:daliang-riben:daban
3,honxian,book-eta-he,london:ddd

3.加载数据

//加载数据到创建的表
laod data local inpath '/home/hadoop/input/load_data.txt' into table person1;

4.创建外部表

//创建外部表
create EXTERNAL table person2(
id int,
name string,
likes ARRAY <string>,
address MAP <string,string>
)
ROW FORMAT DELIMITED
//指定每一项分割
FIELDS TERMINATED BY ','
//指定集合分割
COLLECTION ITEMS TERMINATED BY '_'
//指定Map分割
MAP KEYS TERMINATED BY ':'
//指定存放位置
LOCATION '/home/hadoop/input/person2;

5.其他建表方式

//会插入数据
create table person3
as
select id,name,likes,address from person1;
//不会插入数据
create table person4 like person1;

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值