hive元数据表结构

在debug hive的问题的时候,经常需要分析hive元数据的表结构。
这里简单地说下常用的几个表的结构:

dbs 存储了database的一些信息,id,描述,hdfs中的路径和名称。
tbls 存储了table的一些信息,id,表名等。。其中常用的两个字段是SD_ID和TBL_TYPE,SD_ID后面再说。TBL_TYPE字段 定义了表是外部表(EXTERNAL_TABLE)还是托管表(MANAGED_TABLE)

hive目前的版本是支持view的,view的定义是在tbls表中,TBL_TYPE字段是VIRTUAL_VIEW。

1
2
3
4
5
6
7
8
select distinct TBL_TYPE from tbls;                          
+----------------+
| TBL_TYPE       |
+----------------+
| MANAGED_TABLE  |
| EXTERNAL_TABLE |
| VIRTUAL_VIEW   |
+----------------+

tbls中有另外的两个字段标识了view的sql:

VIEW_EXPANDED_TEXT,VIEW_ORIGINAL_TEXT

其中VIEW_ORIGINAL_TEXT 是创建view时输入的sql,而VIEW_EXPANDED_TEXT是对sql进行规范化之后的结果。

table_params 定义了表的statistics信息和一些表的特性,statistics比如文件数量,分区数量,数据量大小等等,不过目前看来不是很准确,特性比如是否可以drop('PROTECT_MODE'='NO_DROP')等。。

sds 表存储了table到hdfs路径和format,serial等信息,常用的字段是CD_ID和LOCATION,通过tbls的tbl_id字段和sds关联,可以得出表在hdfs中的路径信息和CD_ID

1
2
3
4
5
6
select b.tbl_id,b.tbl_name,c.CD_ID,c.location from dbs a,tbls b,sds c where a.DB_ID=b.DB_ID and b.TBL_NAME='partition_test' and b.SD_ID=c.SD_ID\G;
*************************** 1. row ***************************
  tbl_id: 430381
tbl_name: partition_test
   CD_ID: 431456
location: hdfs://bipcluster/bip/hive_warehouse/cdnlog.db/partition_test

cds表只存储了cd_id字段
columns_v2 表存储了表的column信息,比如字段名称(COLUMN_NAME),字段类型(TYPE_NAME),字段位置(INTEGER_IDX)等
通过tbls和sds的join可以得出表的cd_id,然后再和columns_v2表进行join即可得出表的字段信息,比如上面的表:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
select from columns_v2 where cd_id='431456'\G;
*************************** 1. row ***************************
      CD_ID: 431456
    COMMENT: NULL
COLUMN_NAME: ip
  TYPE_NAME: string
INTEGER_IDX: 0
*************************** 2. row ***************************
      CD_ID: 431456
    COMMENT: NULL
COLUMN_NAME: size
  TYPE_NAME: string
INTEGER_IDX: 2
*************************** 3. row ***************************
      CD_ID: 431456
    COMMENT: NULL
COLUMN_NAME: status
  TYPE_NAME: string
INTEGER_IDX: 1


与partition相关的常用表:
partitions 表分区相关信息,和tbl_id关联,可以获取分区的SD_ID,然后可以获取分区的hdfs路径和column信息。


1
2
3
4
select  a.PART_NAME,b.LOCATION,b.cd_id from partitions  a,sds b where a.tbl_id='430381' and a.sd_id=b.sd_id\G;
PART_NAME: dt=20140121
 LOCATION: hdfs://bipcluster/bip/hive_warehouse/cdnlog.db/partition_test/dt=20140121
    cd_id: 431456

partition_params 和table_params信息一样,存储一些statistics相关的信息
partition_key_vals  分区信息,和 partitions的part_id关联
partition_keys 分区键信息,和tbls的tbl_id关联

权限相关的表:
tbl_privs,tbl_col_privs,db_privs,global_privs,roles,role_map 等。


还有剩下的一些表,用得比较少,以后有机会再来看。。



本文转自菜菜光 51CTO博客,原文链接:http://blog.51cto.com/caiguangguang/1353872,如需转载请自行联系原作者

上一篇:sqlite 二进制字段 (zz)


下一篇:《中国人工智能学会通讯》——2.10 存在的问题