public class HiveCatalog extends AbstractCatalog
AbstractCatalog.TableMeta
Catalog.ColumnAlreadyExistException, Catalog.ColumnNotExistException, Catalog.DatabaseAlreadyExistException, Catalog.DatabaseNoPermissionException, Catalog.DatabaseNotEmptyException, Catalog.DatabaseNotExistException, Catalog.ProcessSystemDatabaseException, Catalog.TableAlreadyExistException, Catalog.TableNoPermissionException, Catalog.TableNotExistException, Catalog.ViewAlreadyExistException, Catalog.ViewNotExistException
Modifier and Type | Field and Description |
---|---|
static String |
HIVE_SITE_FILE |
static String |
PAIMON_TABLE_IDENTIFIER |
static String |
TABLE_TYPE_PROP |
catalogOptions, fileIO, tableDefaultOptions
COMMENT_PROP, DB_LOCATION_PROP, DB_SUFFIX, DEFAULT_DATABASE, LAST_UPDATE_TIME_PROP, NUM_FILES_PROP, NUM_ROWS_PROP, OWNER_PROP, SYSTEM_BRANCH_PREFIX, SYSTEM_DATABASE_NAME, SYSTEM_TABLE_SPLITTER, TABLE_DEFAULT_OPTION_PREFIX, TOTAL_SIZE_PROP
Constructor and Description |
---|
HiveCatalog(FileIO fileIO,
org.apache.hadoop.hive.conf.HiveConf hiveConf,
String clientClassName,
Options options,
String warehouse) |
HiveCatalog(FileIO fileIO,
org.apache.hadoop.hive.conf.HiveConf hiveConf,
String clientClassName,
String warehouse) |
Modifier and Type | Method and Description |
---|---|
protected boolean |
allowCustomTablePath() |
protected void |
alterDatabaseImpl(String name,
List<PropertyChange> changes) |
void |
alterPartitions(Identifier identifier,
List<Partition> partitions)
Alter partitions of the specify table.
|
protected void |
alterTableImpl(Identifier identifier,
List<SchemaChange> changes) |
boolean |
caseSensitive()
Return a boolean that indicates whether this catalog is case-sensitive.
|
CatalogLoader |
catalogLoader()
Serializable loader to create catalog.
|
void |
close() |
protected void |
createDatabaseImpl(String name,
Map<String,String> properties) |
void |
createFormatTable(Identifier identifier,
Schema schema)
Create a
FormatTable identified by the given Identifier . |
static Catalog |
createHiveCatalog(CatalogContext context) |
static org.apache.hadoop.hive.conf.HiveConf |
createHiveConf(CatalogContext context) |
static org.apache.hadoop.hive.conf.HiveConf |
createHiveConf(String hiveConfDir,
String hadoopConfDir,
org.apache.hadoop.conf.Configuration defaultHadoopConf) |
void |
createPartitions(Identifier identifier,
List<Map<String,String>> partitions)
Create partitions of the specify table.
|
protected void |
createTableImpl(Identifier identifier,
Schema schema) |
void |
createView(Identifier identifier,
View view,
boolean ignoreIfExists)
Create a new view.
|
Optional<CatalogLockFactory> |
defaultLockFactory() |
protected void |
dropDatabaseImpl(String name) |
void |
dropPartitions(Identifier identifier,
List<Map<String,String>> partitions)
Drop partitions of the specify table.
|
protected void |
dropTableImpl(Identifier identifier) |
void |
dropView(Identifier identifier,
boolean ignoreIfNotExists)
Drop a view.
|
int |
getBatchGetTableSize() |
Database |
getDatabaseImpl(String name) |
Table |
getDataOrFormatTable(Identifier identifier) |
protected AbstractCatalog.TableMeta |
getDataTableMeta(Identifier identifier) |
TableSchema |
getDataTableSchema(Identifier identifier) |
org.apache.hadoop.hive.metastore.IMetaStoreClient |
getHmsClient() |
org.apache.hadoop.hive.metastore.api.Table |
getHmsTable(Identifier identifier) |
Path |
getTableLocation(Identifier identifier) |
View |
getView(Identifier identifier)
Return a
View identified by the given Identifier . |
static boolean |
isView(org.apache.hadoop.hive.metastore.api.Table table) |
List<String> |
listDatabases()
Get the names of all databases in this catalog.
|
List<Partition> |
listPartitions(Identifier identifier)
Get Partition of all partitions of the table.
|
protected List<String> |
listTablesImpl(String databaseName) |
List<String> |
listViews(String databaseName)
Get names of all views under this database.
|
Optional<CatalogLockContext> |
lockContext() |
void |
markDonePartitions(Identifier identifier,
List<Map<String,String>> partitions)
Mark partitions done of the specify table.
|
static String |
possibleHiveConfPath() |
protected void |
renameTableImpl(Identifier fromTable,
Identifier toTable) |
void |
renameView(Identifier fromView,
Identifier toView,
boolean ignoreIfNotExists)
Rename a view.
|
void |
repairCatalog()
Repair the entire Catalog, repair the metadata in the metastore consistent with the metadata
in the filesystem, register missing tables in the metastore.
|
void |
repairDatabase(String databaseName)
Repair the entire database, repair the metadata in the metastore consistent with the metadata
in the filesystem, register missing tables in the metastore.
|
void |
repairTable(Identifier identifier)
Repair the table, repair the metadata in the metastore consistent with the metadata in the
filesystem.
|
boolean |
syncAllProperties() |
String |
warehouse()
Warehouse root path for creating new databases.
|
alterDatabase, alterTable, assertMainBranch, createDatabase, createTable, dropDatabase, dropTable, fileIO, getDatabase, getTable, listDatabasesInFileSystem, listTables, listTablesInFileSystem, lockEnabled, lockFactory, newDatabasePath, newDatabasePath, newTableLocation, objectFileIO, options, renameTable, tableExistsInFileSystem, tableSchemaInFileSystem
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
alterTable, createDatabase, invalidateTable
public static final String TABLE_TYPE_PROP
public static final String PAIMON_TABLE_IDENTIFIER
public static final String HIVE_SITE_FILE
public HiveCatalog(FileIO fileIO, org.apache.hadoop.hive.conf.HiveConf hiveConf, String clientClassName, String warehouse)
public Optional<CatalogLockFactory> defaultLockFactory()
defaultLockFactory
in class AbstractCatalog
public Optional<CatalogLockContext> lockContext()
lockContext
in class AbstractCatalog
public Path getTableLocation(Identifier identifier)
getTableLocation
in class AbstractCatalog
public List<String> listDatabases()
Catalog
protected void createDatabaseImpl(String name, Map<String,String> properties)
createDatabaseImpl
in class AbstractCatalog
public Database getDatabaseImpl(String name) throws Catalog.DatabaseNotExistException
getDatabaseImpl
in class AbstractCatalog
Catalog.DatabaseNotExistException
public void createPartitions(Identifier identifier, List<Map<String,String>> partitions) throws Catalog.TableNotExistException
Catalog
Only catalog with metastore can support this method, and only table with 'metastore.partitioned-table' can support this method.
createPartitions
in interface Catalog
createPartitions
in class AbstractCatalog
identifier
- path of the table to create partitionspartitions
- partitions to be createdCatalog.TableNotExistException
- if the table does not existpublic void dropPartitions(Identifier identifier, List<Map<String,String>> partitions) throws Catalog.TableNotExistException
Catalog
dropPartitions
in interface Catalog
dropPartitions
in class AbstractCatalog
identifier
- path of the table to drop partitionspartitions
- partitions to be deletedCatalog.TableNotExistException
- if the table does not existpublic void alterPartitions(Identifier identifier, List<Partition> partitions) throws Catalog.TableNotExistException
Catalog
Only catalog with metastore can support this method, and only table with 'metastore.partitioned-table' can support this method.
alterPartitions
in interface Catalog
alterPartitions
in class AbstractCatalog
identifier
- path of the table to alter partitionspartitions
- partitions to be alteredCatalog.TableNotExistException
- if the table does not existpublic void markDonePartitions(Identifier identifier, List<Map<String,String>> partitions) throws Catalog.TableNotExistException
Catalog
Only catalog with metastore can support this method, and only table with 'metastore.partitioned-table' can support this method.
markDonePartitions
in interface Catalog
markDonePartitions
in class AbstractCatalog
identifier
- path of the table to mark done partitionspartitions
- partitions to be marked doneCatalog.TableNotExistException
- if the table does not existpublic List<Partition> listPartitions(Identifier identifier) throws Catalog.TableNotExistException
Catalog
listPartitions
in interface Catalog
listPartitions
in class AbstractCatalog
identifier
- path of the table to list partitionsCatalog.TableNotExistException
- if the table does not existprotected void dropDatabaseImpl(String name)
dropDatabaseImpl
in class AbstractCatalog
protected void alterDatabaseImpl(String name, List<PropertyChange> changes)
alterDatabaseImpl
in class AbstractCatalog
protected List<String> listTablesImpl(String databaseName)
listTablesImpl
in class AbstractCatalog
protected AbstractCatalog.TableMeta getDataTableMeta(Identifier identifier) throws Catalog.TableNotExistException
getDataTableMeta
in class AbstractCatalog
Catalog.TableNotExistException
public TableSchema getDataTableSchema(Identifier identifier) throws Catalog.TableNotExistException
getDataTableSchema
in class AbstractCatalog
Catalog.TableNotExistException
public View getView(Identifier identifier) throws Catalog.ViewNotExistException
Catalog
View
identified by the given Identifier
.identifier
- Path of the viewCatalog.ViewNotExistException
- if the target does not existpublic void createView(Identifier identifier, View view, boolean ignoreIfExists) throws Catalog.ViewAlreadyExistException, Catalog.DatabaseNotExistException
Catalog
identifier
- path of the view to be createdview
- the view definitionignoreIfExists
- flag to specify behavior when a view already exists at the given path:
if set to false, it throws a ViewAlreadyExistException, if set to true, do nothing.Catalog.ViewAlreadyExistException
- if view already exists and ignoreIfExists is falseCatalog.DatabaseNotExistException
- if the database in identifier doesn't existpublic void dropView(Identifier identifier, boolean ignoreIfNotExists) throws Catalog.ViewNotExistException
Catalog
identifier
- Path of the view to be droppedignoreIfNotExists
- Flag to specify behavior when the view does not exist: if set to
false, throw an exception, if set to true, do nothing.Catalog.ViewNotExistException
- if the view does not existpublic List<String> listViews(String databaseName) throws Catalog.DatabaseNotExistException
Catalog
Catalog.DatabaseNotExistException
- if the database does not existpublic void renameView(Identifier fromView, Identifier toView, boolean ignoreIfNotExists) throws Catalog.ViewNotExistException, Catalog.ViewAlreadyExistException
Catalog
fromView
- identifier of the view to renametoView
- new view identifierCatalog.ViewNotExistException
- if the fromView does not existCatalog.ViewAlreadyExistException
- if the toView already existspublic Table getDataOrFormatTable(Identifier identifier) throws Catalog.TableNotExistException
getDataOrFormatTable
in class AbstractCatalog
Catalog.TableNotExistException
public void createFormatTable(Identifier identifier, Schema schema)
AbstractCatalog
FormatTable
identified by the given Identifier
.createFormatTable
in class AbstractCatalog
identifier
- Path of the tableschema
- Schema of the tableprotected void dropTableImpl(Identifier identifier)
dropTableImpl
in class AbstractCatalog
protected void createTableImpl(Identifier identifier, Schema schema)
createTableImpl
in class AbstractCatalog
protected void renameTableImpl(Identifier fromTable, Identifier toTable)
renameTableImpl
in class AbstractCatalog
protected void alterTableImpl(Identifier identifier, List<SchemaChange> changes) throws Catalog.TableNotExistException, Catalog.ColumnAlreadyExistException, Catalog.ColumnNotExistException
alterTableImpl
in class AbstractCatalog
Catalog.TableNotExistException
Catalog.ColumnAlreadyExistException
Catalog.ColumnNotExistException
public boolean caseSensitive()
Catalog
protected boolean allowCustomTablePath()
allowCustomTablePath
in class AbstractCatalog
public boolean syncAllProperties()
public void repairCatalog()
Catalog
public void repairDatabase(String databaseName)
Catalog
public void repairTable(Identifier identifier) throws Catalog.TableNotExistException
Catalog
Catalog.TableNotExistException
public String warehouse()
Catalog
public CatalogLoader catalogLoader()
Catalog
public org.apache.hadoop.hive.metastore.api.Table getHmsTable(Identifier identifier) throws Catalog.TableNotExistException
Catalog.TableNotExistException
public static boolean isView(org.apache.hadoop.hive.metastore.api.Table table)
@VisibleForTesting public org.apache.hadoop.hive.metastore.IMetaStoreClient getHmsClient()
public static org.apache.hadoop.hive.conf.HiveConf createHiveConf(@Nullable String hiveConfDir, @Nullable String hadoopConfDir, org.apache.hadoop.conf.Configuration defaultHadoopConf)
public static Catalog createHiveCatalog(CatalogContext context)
public static org.apache.hadoop.hive.conf.HiveConf createHiveConf(CatalogContext context)
public static String possibleHiveConfPath()
public int getBatchGetTableSize()
Copyright © 2023–2025 The Apache Software Foundation. All rights reserved.