These statements provide a way to query the Hive metastore for existing data and metadata accessible to this Hive system. Show Databases Code Block |
---|
SHOW (DATABASES|SCHEMAS) [LIKE 'identifier_with_wildcards'];
|
SHOW DATABASES or SHOW SCHEMAS lists all of the databases defined in the metastore. The uses of SCHEMAS and DATABASES are interchangeable – they mean the same thing. The optional LIKE clause allows the list of databases to be filtered using a regular expression. Wildcards in the regular expression can only be '*' for any character(s) or '|' for a choice. Examples are 'employees', 'emp*', 'emp*|*ees', all of which will match the database named 'employees'. Anchor |
---|
| Show Tables/Partitions/Indexes |
---|
| Show Tables/Partitions/Indexes |
---|
|
Info |
---|
title | Version information: SHOW DATABASES |
---|
| Starting from 4.0.0 we accept only SQL type like expressions containing '%' for any character(s), and '_' for a single character. Examples are 'employees', 'emp%', 'emplo_ees', all of which will match the database named 'employees'. |
Show Connectors Code Block |
---|
SHOW CONNECTORS;
|
Since Hive 4.0.0 via HIVE-24396 SHOW CONNECTORS lists all of the connectors defined in the metastore (depending on the user's access). Show Tables/Views/Materialized Views/Partitions/IndexesShow Tables Code Block |
---|
SHOW TABLES [IN database_name] ['identifier_with_wildcards'];
|
SHOW TABLES lists all the base tables and views in the current database (or the one explicitly named using the IN clause) with names matching the optional regular expression. Wildcards in the regular expression can only be '*' for any character(s) or '|' for a choice. Examples are 'page_view', 'page_v*', '*view|page*', all which will match the 'page_view' table. Matching tables are listed in alphabetical order. It is not an error if there are no matching tables found in metastore. If no regular expression is given then all tables in the selected database are listed.
Show Views
Code Block |
---|
SHOW VIEWS [IN/FROM database_name] [LIKE 'pattern_with_wildcards']; |
SHOW VIEWS lists all the views in the current database (or the one explicitly named using the IN or FROM clause) with names matching the optional regular expression. Wildcards in the regular expression can only be '*' for any character(s) or '|' for a choice. Examples are 'page_view', 'page_v*', '*view|page*', all which will match the 'page_view' view. Matching views are listed in alphabetical order. It is not an error if no matching views are found in metastore. If no regular expression is given then all views in the selected database are listed.
Code Block |
---|
| SHOW VIEWS; -- show all views in the current database
SHOW VIEWS 'test_*'; -- show all views that start with "test_"
SHOW VIEWS '*view2'; -- show all views that end in "view2"
SHOW VIEWS LIKE 'test_view1|test_view2'; -- show views named either "test_view1" or "test_view2"
SHOW VIEWS FROM test1; -- show views from database test1
SHOW VIEWS IN test1; -- show views from database test1 (FROM and IN are same)
SHOW VIEWS IN test1 "test_*"; -- show views from database test2 that start with "test_" |
Show Materialized Views Code Block |
---|
SHOW MATERIALIZED VIEWS [IN/FROM database_name] [LIKE 'pattern_with_wildcards’]; |
SHOW MATERIALIZED VIEWS lists all the views in the current database (or the one explicitly named using the IN or FROM clause) with names matching the optional regular expression. It also shows additional information about the materialized view, e.g., whether rewriting is enabled, and the refresh mode for the materialized view. Wildcards in the regular expression can only be '*' for any character(s) or '|' for a choice. If no regular expression is given then all materialized views in the selected database are listed.
Show Partitions Code Block |
---|
SHOW PARTITIONS table_name;
|
SHOW PARTITIONS lists all the existing partitions for a given base table. Partitions are listed in alphabetical order. Info |
---|
| As of Hive 0.6, SHOW PARTITIONS can filter the list of partitions as shown below. |
It is also possible to specify parts of a partition specification to filter the resulting list. Code Block |
---|
| SHOW PARTITIONS table_name PARTITION(ds='2010-03-03'); -- (Note: Hive 0.6 and later)
SHOW PARTITIONS table_name PARTITION(hr='12'); -- (Note: Hive 0.6 and later)
SHOW PARTITIONS table_name PARTITION(ds='2010-03-03', hr='12'); -- (Note: Hive 0.6 and later)
|
Info |
---|
| Starting with Hive 0.13.0, SHOW PARTITIONS can specify a database (HIVE-5912). |
Code Block |
---|
SHOW PARTITIONS [db_name.]table_name [PARTITION(partition_spec)]; -- (Note: Hive 0.13.0 and later)
|
Code Block |
---|
| SHOW PARTITIONS databaseFoo.tableBar PARTITION(ds='2010-03-03', hr='12'); -- (Note: Hive 0.13.0 and later)
|
Info |
---|
| Starting with Hive 4.0.0, SHOW PARTITIONS can optionally use the WHERE/ORDER BY/LIMIT clause to filter/order/limit the resulting list (HIVE-22458). These clauses work in a similar way as they do in a SELECT statement. |
Code Block |
---|
SHOW PARTITIONS [db_name.]table_name [PARTITION(partition_spec)] [WHERE where_condition] [ORDER BY col_list] [LIMIT rows]; -- (Note: Hive 4.0.0 and later)
|
Code Block |
---|
| SHOW PARTITIONS databaseFoo.tableBar LIMIT 10; -- (Note: Hive 4.0.0 and later)
SHOW PARTITIONS databaseFoo.tableBar PARTITION(ds='2010-03-03') LIMIT 10; -- (Note: Hive 4.0.0 and later)
SHOW PARTITIONS databaseFoo.tableBar PARTITION(ds='2010-03-03') ORDER BY hr DESC LIMIT 10; -- (Note: Hive 4.0.0 and later)
SHOW PARTITIONS databaseFoo.tableBar PARTITION(ds='2010-03-03') WHERE hr >= 10 ORDER BY hr DESC LIMIT 10; -- (Note: Hive 4.0.0 and later)
SHOW PARTITIONS databaseFoo.tableBar WHERE hr >= 10 AND ds='2010-03-03' ORDER BY hr DESC LIMIT 10; -- (Note: Hive 4.0.0 and later) |
Note: Please use hr >= 10 instead of hr - 10 >= 0 to filter the results, as Metastore would not push the latter predicate down into the underlying storage. Show Table/Partition Extended Code Block |
---|
SHOW TABLE EXTENDED [IN|FROM database_name] LIKE 'identifier_with_wildcards' [PARTITION(partition_spec)];
|
SHOW TABLE EXTENDED will list information for all tables matching the given regular expression. Users cannot use regular expression for table name if a partition specification is present. This command's output includes basic table information and file system information like totalNumberFiles, totalFileSize, maxFileSize, minFileSize,lastAccessTime, and lastUpdateTime. If partition is present, it will output the given partition's file system information instead of table's file system information.
Code Block |
---|
| hive> show table extended like part_table;
OK
tableName:part_table
owner:thejas
location:file:/tmp/warehouse/part_table
inputformat:org.apache.hadoop.mapred.TextInputFormat
outputformat:org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat
columns:struct columns { i32 i}
partitioned:true
partitionColumns:struct partition_columns { string d}
totalNumberFiles:1
totalFileSize:2
maxFileSize:2
minFileSize:2
lastAccessTime:0
lastUpdateTime:1459382233000
|
Show Table Properties
Code Block |
---|
SHOW TBLPROPERTIES tblname;
SHOW TBLPROPERTIES tblname("foo");
|
The first form lists all of the table properties for the table in question, one per row separated by tabs. The second form of the command prints only the value for the property that's being asked for. For more information, see the TBLPROPERTIES clause in Create Table above. Show Create Table
Code Block |
---|
SHOW CREATE TABLE ([db_name.]table_name|view_name);
|
SHOW CREATE TABLE shows the CREATE TABLE statement that creates a given table, or the CREATE VIEW statement that creates a given view. Show Indexes
Code Block |
---|
SHOW [FORMATTED] (INDEX|INDEXES) ON table_with_index [(FROM|IN) db_name];
|
SHOW INDEXES shows all of the indexes on a certain column, as well as information about them: index name, table name, names of the columns used as keys, index table name, index type, and comment. If the FORMATTED keyword is used, then column titles are printed for each column. Show Columns
Code Block |
---|
SHOW COLUMNS (FROM|IN) table_name [(FROM|IN) db_name];
|
SHOW COLUMNS shows all the columns in a table including partition columns.
Info |
---|
| SHOW COLUMNS (FROM|IN) table_name [(FROM|IN) db_name] [ LIKE 'pattern_with_wildcards' ] ; Added in Hive 3.0 by HIVE-18373. |
SHOW COLUMNS lists all the columns in the table with names matching the optional regular expression. Wildcards in the regular expression can only be '*' for any character(s) or '|' for a choice. Examples are 'cola', 'col*', '*a|col*', all which will match the 'cola' column. Matching columns are listed in alphabetical order. It is not an error if no matching columns are found in table. If no regular expression is given then all columns in the selected table are listed.
Code Block |
---|
| -- SHOW COLUMNS
CREATE DATABASE test_db;
USE test_db;
CREATE TABLE foo(col1 INT, col2 INT, col3 INT, cola INT, colb INT, colc INT, a INT, b INT, c INT);
-- SHOW COLUMNS basic syntax
SHOW COLUMNS FROM foo; -- show all column in foo
SHOW COLUMNS FROM foo "*"; -- show all column in foo
SHOW COLUMNS IN foo "col*"; -- show columns in foo starting with "col" OUTPUT col1,col2,col3,cola,colb,colc
SHOW COLUMNS FROM foo '*c'; -- show columns in foo ending with "c" OUTPUT c,colc
SHOW COLUMNS FROM foo LIKE "col1|cola"; -- show columns in foo either col1 or cola OUTPUT col1,cola
SHOW COLUMNS FROM foo FROM test_db LIKE 'col*'; -- show columns in foo starting with "col" OUTPUT col1,col2,col3,cola,colb,colc
SHOW COLUMNS IN foo IN test_db LIKE 'col*'; -- show columns in foo starting with "col" (FROM/IN same) OUTPUT col1,col2,col3,cola,colb,colc
-- Non existing column pattern resulting in no match
SHOW COLUMNS IN foo "nomatch*";
SHOW COLUMNS IN foo "col+"; -- + wildcard not supported
SHOW COLUMNS IN foo "nomatch"; |
Show Functions Code Block |
---|
SHOW FUNCTIONS [LIKE "<pattern>"]; |
SHOW FUNCTIONS lists all the user defined and builtin functions, filtered by the the regular expression if specified with LIKE. Show Granted Roles and PrivilegesHive deprecated authorization mode / Legacy Mode has information about these SHOW statements: In Hive 0.13.0 and later releases, SQL standard based authorization has these SHOW statements: Show Locks Code Block |
---|
| SHOW LOCKS <table_name>;
SHOW LOCKS <table_name> EXTENDED;
SHOW LOCKS <table_name> PARTITION (<partition_spec>);
SHOW LOCKS <table_name> PARTITION (<partition_spec>) EXTENDED;
SHOW LOCKS (DATABASE|SCHEMA) database_name; -- (Note: Hive 0.13.0 and later; SCHEMA added in Hive 0.14.0) |
SHOW LOCKS displays the locks on a table or partition. See Hive Concurrency Model for information about locks. SHOW LOCKS (DATABASE|SCHEMA) is supported from Hive 0.13 for DATABASE (see HIVE-2093) and Hive 0.14 for SCHEMA (see HIVE-6601). SCHEMA and DATABASE are interchangeable – they mean the same thing. When Hive transactions are being used, SHOW LOCKS returns this information (see HIVE-6460): - database name
- table name
- partition name (if the table is partitioned)
- the state the lock is in, which can be:
- "acquired" – the requestor holds the lock
- "waiting" – the requestor is waiting for the lock
- "aborted" – the lock has timed out but has not yet been cleaned up
- Id of the lock blocking this one, if this lock is in "waiting" state
- the type of lock, which can be:
- "exclusive" – no one else can hold the lock at the same time (obtained mostly by DDL operations such as drop table)
- "shared_read" – any number of other shared_read locks can lock the same resource at the same time (obtained by reads; confusingly, an insert operation also obtains a shared_read lock)
- "shared_write" – any number of shared_read locks can lock the same resource at the same time, but no other shared_write locks are allowed (obtained by update and delete)
- ID of the transaction this lock is associated with, if there is one
- last time the holder of this lock sent a heartbeat indicating it was still alive
- the time the lock was acquired, if it has been acquired
- Hive user who requested the lock
- host the user is running on
- agent info – a string that helps identify the entity that issued the lock request. For a SQL client this is the query ID, for streaming client it may be Storm bolt ID for example.
Show Conf
Code Block |
---|
| SHOW CONF <configuration_name>; |
SHOW CONF returns a description of the specified configuration property. - default value
- required type
- description
Note that SHOW CONF does not show the current value of a configuration property. For current property settings, use the "set" command in the CLI or a HiveQL script (see Commands) or in Beeline (see Beeline Hive Commands). Show Transactions
Code Block |
---|
| SHOW TRANSACTIONS; |
SHOW TRANSACTIONS is for use by administrators when Hive transactions are being used. It returns a list of all currently open and aborted transactions in the system, including this information: - transaction ID
- transaction state
- user who started the transaction
- machine where the transaction was started
- timestamp when the transaction was started (as of Hive 2.2.0)
- timestamp for last heartbeat (as of Hive 2.2.0 )
Show Compactions
Code Block |
---|
| SHOW COMPACTIONS [DATABASE.][TABLE] [PARTITION (<partition_spec>)] [POOL_NAME] [TYPE] [STATE] [ORDER BY `start` DESC] [LIMIT 10]; |
SHOW COMPACTIONS returns a list of all tables and partitions compaction requests currently being compacted processed or scheduled for compaction when Hive transactions are being used, including this information: - "CompactionId" - unique internal id (As of Hive 3.0)
- "Database" - Hive database name
- "Table" - table name
- "Partition" - partition name (if the table is partitioned)
- "Type" - whether it is a major or minor compaction
- "State" - the state the compaction is in, which can be:
- "initiated" – waiting in the queue to be compacted
- "working" – being compacted
- "ready for cleaning" – the compaction has been done and the old files are scheduled to be cleaned
- "failed" – the job failed. The metastore log will have more detail.
- "succeeded" – A-ok
- "attempted" – initiator attempted to schedule a compaction but failed. The metastore log will have more information.
- "Worker" - thread ID of the worker thread doing the compaction (only if in working state)
- "Start Time" - the time at which the compaction started (only if in working or ready for cleaning state)
- "Duration(ms)" - time this compaction took (As of Hive 2.2 )
- "HadoopJobId" - Id of the submitted Hadoop job (As of Hive 2.2)
- “Enqueue Time” - Time spent by compaction before start
- “Initiator host”- Host ID which started compaction
- “TxnId” - A transaction Id associated with this compaction
- “Commit Time” - Total time taken by compaction
- “Highest WriteId” Highest writeId that compactor includes
- “Pool name”- A pool associated with given compaction or default if not associated
- “Error message”- error message if any
Examples: Code Block |
---|
| Examples
SHOW COMPACTIONS.
— show all compactions of all tables and partitions currently being compacted or scheduled for compaction
SHOW COMPACTIONS DATABASE db1
— show all compactions of all tables from given database which are currently being compacted or scheduled for compaction
SHOW COMPACTIONS SCHEMA db1
— show all compactions of all tables from given database which are currently being compacted or scheduled for compaction
SHOW COMPACTIONS tbl0
— show all compactions from given table which are currently being compacted or scheduled for compaction
SHOW COMPACTIONS compactionid =1
— show all compactions with given compaction ID
SHOW COMPACTIONS db1.tbl0 PARTITION (p=101,day='Monday') POOL 'pool0' TYPE 'minor' STATUS 'ready for clean' ORDER BY cq_table DESC, cq_state LIMIT 42
— show all compactions from specific database/table filtered based on pool name/type.state/status and ordered with given clause |
Compactions are initiated automatically, but can also be initiated manually with an ALTER TABLE COMPACT statement. |