hive 分区

create table day_table (id int, content string) partitioned by (dt string);

schematool -dbType MySQL -initSchema


动态分区

set hive.exec.dynamic.partition=true;

set hive.exec.dynamic.partition.mode=nonstrict;




 

INSERT OVERWRITE TABLE target PARTITION (dt)
SELECT id,user_id,app_id,time,ip,substr(time,0,10) FROM origin

可以将老数据load 到hive表中后, 然后在用insert select 方式给老数据创建分区。

 

在处理好老数据分区后,用静态分区:

 

create table partuserview(userid string,hourid string,cityid string,fronturl string,contentype int)  partitioned by (dt string) row format delimited fields terminated by '\t';

load data local inpath '/home/xincl/hive-0.6.0/data/userview.txt' into table partuserview partition(dt='20101110');

 

创建bucket表语句:
> create  table butuserview(userid string,hourid string,cityid string,fronturl string,contentype int)  clustered by (hourid) into 12 buckets row format delimited fields terminated by '\t';
上面指定使用hourid来做bucket,有12个bucket。用hourid的hashcode MOD bucket个数。

 


sqoop 引用分区:


  sqoop import --connect jdbc:postgresql://ip/db_name --username user_name  --table table_name  --hive-import -m 5 --hive-table hive_table_name  (--hive-partition-key partition_name --hive-partition-value partititon_value);

 

 

修改字段类型:

 ALTER TABLE MUSER_BASICINFO_CPA CHANGE USERINDEX USERINDEX bigint;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值