Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/84.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 有没有一种简单的方法可以从配置单元中的托管表创建分区表?_Mysql_Sql_Hadoop_Hive_Partition - Fatal编程技术网

Mysql 有没有一种简单的方法可以从配置单元中的托管表创建分区表?

Mysql 有没有一种简单的方法可以从配置单元中的托管表创建分区表?,mysql,sql,hadoop,hive,partition,Mysql,Sql,Hadoop,Hive,Partition,我在配置单元中有一个托管表,我希望基于它的一列对其进行分区。 有没有一种简单的方法可以从这个托管表创建分区表 托管表a(s、d、f、g、h、j、k、键) 将表b创建为按键分区的表a 谢谢您可以通过动态分区来实现这一点: 以下是一个例子: 我有一些日志数据,有字段 id、tdate、info 我已经创建了一个动态分区表 CREATE TABLE log_partitioned(id STRING, info STRING) PARTITIONED BY ( tdate STRING) 然后加

我在配置单元中有一个托管表,我希望基于它的一列对其进行分区。 有没有一种简单的方法可以从这个托管表创建分区表

托管表a(s、d、f、g、h、j、k、键)

将表b创建为按键分区的表a


谢谢

您可以通过动态分区来实现这一点:

以下是一个例子: 我有一些日志数据,有字段

id、tdate、info 我已经创建了一个动态分区表

CREATE TABLE log_partitioned(id STRING,  info STRING)
PARTITIONED BY ( tdate STRING) 
然后加载数据

FROM logs lg
INSERT OVERWRITE TABLE log_partitioned PARTITION(tdate)
SELECT lg.id, lg.info, lg.tdate
DISTRIBUTE BY tdate;
它将通过动态分区从托管表成功加载数据

我发现这个教程非常有用。请参阅此“