hive建表语句中external, terminated, partitioned, stored 全解析

从官网的建表语句切入我的分析:

`CREATE [TEMPORARY] [EXTERNAL] TABLE [IF NOT EXISTS] [db_name.]table_name    -- (Note: TEMPORARY available in Hive``0.14``.``0``and later)`

`[(col_name data_type [column_constraint_specification] [COMMENT col_comment], ... [constraint_specification])]`

`[COMMENT table_comment]`

`[PARTITIONED BY (col_name data_type [COMMENT col_comment], ...)]`

`[CLUSTERED BY (col_name, col_name, ...) [SORTED BY (col_name [ASC|DESC], ...)] INTO num_buckets BUCKETS]`

`[SKEWED BY (col_name, col_name, ...)                  -- (Note: Available in Hive``0.10``.``0``and later)]`

`ON ((col_value, col_value, ...), (col_value, col_value, ...), ...)`

`[STORED AS DIRECTORIES]`

`[`

`[ROW FORMAT row_format] `

`[STORED AS file_format]`

`| STORED BY``'storage.handler.class.name'``[WITH SERDEPROPERTIES (...)]  -- (Note: Available in Hive``0.6``.``0``and later)`

`]`

`[LOCATION hdfs_path]`

`[TBLPROPERTIES (property_name=property_value, ...)]   -- (Note: Available in Hive``0.6``.``0``and later)`

`[AS select_statement];   -- (Note: Available in Hive``0.5``.``0``and later; not supported``for``external tables)`

`CREATE [TEMPORARY] [EXTERNAL] TABLE [IF NOT EXISTS] [db_name.]table_name`

`LIKE existing_table_or_view_name`

`[LOCATION hdfs_path];`

`data_type`

`: primitive_type`

`| array_type`

`| map_type`

`| struct_type`

`| union_type  -- (Note: Available in Hive``0.7``.``0``and later)`

`primitive_type`

`: TINYINT`

`| SMALLINT`

`| INT`

`| BIGINT`

`| BOOLEAN`

`| FLOAT`

`| DOUBLE`

`| DOUBLE PRECISION -- (Note: Available in Hive``2.2``.``0``and later)`

`| STRING`

`| BINARY      -- (Note: Available in Hive``0.8``.``0``and later)`

`| TIMESTAMP   -- (Note: Available in Hive``0.8``.``0``and later)`

`| DECIMAL     -- (Note: Available in Hive``0.11``.``0``and later)`

`| DECIMAL(precision, scale)  -- (Note: Available in Hive``0.13``.``0``and later)`

`| DATE        -- (Note: Available in Hive``0.12``.``0``and later)`

`| VARCHAR     -- (Note: Available in Hive``0.12``.``0``and later)`

`| CHAR        -- (Note: Available in Hive``0.13``.``0``and later)`

`array_type`

`: ARRAY < data_type >`

`map_type`

`: MAP < primitive_type, data_type >`

`struct_type`

`: STRUCT < col_name : data_type [COMMENT col_comment], ...>`

`union_type`

`: UNIONTYPE < data_type, data_type, ... >  -- (Note: Available in Hive``0.7``.``0``and later)`

`row_format`

`: DELIMITED [FIELDS TERMINATED BY``char``[ESCAPED BY``char``]] [COLLECTION ITEMS TERMINATED BY``char``]`

`[MAP KEYS TERMINATED BY``char``] [LINES TERMINATED BY``char``]`

`[NULL DEFINED AS``char``]   -- (Note: Available in Hive``0.13``and later)`

`| SERDE serde_name [WITH SERDEPROPERTIES (property_name=property_value, property_name=property_value, ...)]`

`file_format:`

`: SEQUENCEFILE`

`| TEXTFILE    -- (Default, depending on hive.``default``.fileformat configuration)`

`| RCFILE      -- (Note: Available in Hive``0.6``.``0``and later)`

`| ORC         -- (Note: Available in Hive``0.11``.``0``and later)`

`| PARQUET     -- (Note: Available in Hive``0.13``.``0``and later)`

`| AVRO        -- (Note: Available in Hive``0.14``.``0``and later)`

`| JSONFILE    -- (Note: Available in Hive``4.0``.``0``and later)`

`| INPUTFORMAT input_format_classname OUTPUTFORMAT output_format_classname`

`column_constraint_specification:`

`: [ PRIMARY KEY|UNIQUE|NOT NULL|DEFAULT [default_value]|CHECK  [check_expression] ENABLE|DISABLE NOVALIDATE RELY/NORELY ]`

`default_value:`

`: [ LITERAL|CURRENT_USER()|CURRENT_DATE()|CURRENT_TIMESTAMP()|NULL ] `

`constraint_specification:`

`: [, PRIMARY KEY (col_name, ...) DISABLE NOVALIDATE RELY/NORELY ]`

`[, PRIMARY KEY (col_name, ...) DISABLE NOVALIDATE RELY/NORELY ]`

`[, CONSTRAINT constraint_name FOREIGN KEY (col_name, ...) REFERENCES table_name(col_name, ...) DISABLE NOVALIDATE `

`[, CONSTRAINT constraint_name UNIQUE (col_name, ...) DISABLE NOVALIDATE RELY/NORELY ]`

`[, CONSTRAINT constraint_name CHECK [check_expression] ENABLE|DISABLE NOVALIDATE RELY/NORELY ]`

外部表or管理表之分——external

分隔符设定——terminated

ROW FORMAT DELIMITED 分隔符设置开始语句
FIELDS TERMINATED BY:设置字段与字段之间的分隔符
COLLECTION ITEMS TERMINATED BY:设置一个复杂类型(array,struct)字段的各个item之间的分隔符
MAP KEYS TERMINATED BY:设置一个复杂类型(Map)字段的key value之间的分隔符
LINES TERMINATED BY:设置行与行之间的分隔符
例:

你可能感兴趣的:(hive,sql)