你会Hive表的基本操作吗?

来源:柯同学 Java大数据与数据仓库 日期:2021-02-21

本文转载自微信公众号「Java大数据与数据仓库」,作者柯同学。转载本文请联系Java大数据与数据仓库公众号。 

1. 创建表

create table语句遵从sql语法习惯,只不过Hive的语法更灵活。例如,可以定义表的数据文件存储位置,使用的存储格式等。

  1. create table if not exists test.user1( 
  2. name string comment 'name'
  3. salary float comment 'salary'
  4. address struct<country:string, city:string> comment 'home address' 
  5. comment 'description of the table' 
  6. partitioned by (age int
  7. row format delimited fields terminated by '\t' 
  8. stored as orc; 

没有指定external关键字,则为管理表,跟mysql一样,if not exists如果表存在则不做操作,否则则新建表。comment可以为其做注释,分区为age年龄,列之间分隔符是\t,存储格式为列式存储orc,存储位置为默认位置,即参数hive.metastore.warehouse.dir(默认:/user/hive/warehouse)指定的hdfs目录。

2. 拷贝表

使用like可以拷贝一张跟原表结构一样的空表,里面是没有数据的。

  1. create table if not exists test.user2 like test.user1; 

3. 查看表结构

通过desc [可选参数] tableName命令查看表结构,可以看出拷贝的表test.user1与原表test.user1的表结构是一样的。

  1. hive> desc test.user2; 
  2. OK 
  3. name                    string                  name                 
  4. salary                  float                   salary               
  5. address                 struct<country:string,city:string>  home address         
  6. age                     int                                          
  7.  
  8. # Partition Information          
  9. # col_name                data_type               comment              
  10.  
  11. age                     int          

也可以加formatted,可以看到更加详细和冗长的输出信息。

  1. hive> desc formatted test.user2; 
 1/5    1 2 3 4 5 下一页 尾页
    A+
声明:本文转载自其它媒体,转载目的在于传递更多信息,并不代表赞同其观点和对其真实性负责。