public class NessieCatalog extends BaseMetastoreViewCatalog implements SupportsNamespaces, Configurable<java.lang.Object>
BaseMetastoreViewCatalog.BaseMetastoreViewCatalogTableBuilder, BaseMetastoreViewCatalog.BaseViewBuilderBaseMetastoreCatalog.BaseMetastoreCatalogTableBuilderCatalog.TableBuilder| Constructor and Description |
|---|
NessieCatalog() |
| Modifier and Type | Method and Description |
|---|---|
void |
close() |
void |
createNamespace(Namespace namespace,
java.util.Map<java.lang.String,java.lang.String> metadata)
Create a namespace in the catalog.
|
protected java.lang.String |
defaultWarehouseLocation(TableIdentifier table) |
boolean |
dropNamespace(Namespace namespace)
Drop a namespace.
|
boolean |
dropTable(TableIdentifier identifier,
boolean purge)
Drop a table; optionally delete data and metadata files.
|
boolean |
dropView(TableIdentifier identifier)
Drop a view.
|
void |
initialize(java.lang.String name,
java.util.Map<java.lang.String,java.lang.String> options)
Initialize a view catalog given a custom name and a map of catalog properties.
|
void |
initialize(java.lang.String name,
NessieIcebergClient client,
FileIO fileIO,
java.util.Map<java.lang.String,java.lang.String> catalogOptions)
An alternative way to initialize the catalog using a pre-configured
NessieIcebergClient
and FileIO instance. |
java.util.List<Namespace> |
listNamespaces(Namespace namespace)
List child namespaces from the namespace.
|
java.util.List<TableIdentifier> |
listTables(Namespace namespace)
Return all the identifiers under this namespace.
|
java.util.List<TableIdentifier> |
listViews(Namespace namespace)
Return all the identifiers under this namespace.
|
java.util.Map<java.lang.String,java.lang.String> |
loadNamespaceMetadata(Namespace namespace)
Load the given namespace and return its properties.
|
java.lang.String |
name()
Return the name for this catalog.
|
protected TableOperations |
newTableOps(TableIdentifier tableIdentifier) |
protected ViewOperations |
newViewOps(TableIdentifier identifier) |
protected java.util.Map<java.lang.String,java.lang.String> |
properties() |
boolean |
removeProperties(Namespace namespace,
java.util.Set<java.lang.String> properties)
Remove a set of property keys from a namespace in the catalog.
|
void |
renameTable(TableIdentifier from,
TableIdentifier to)
Rename a table.
|
void |
renameView(TableIdentifier from,
TableIdentifier to)
Rename a view.
|
void |
setConf(java.lang.Object conf) |
boolean |
setProperties(Namespace namespace,
java.util.Map<java.lang.String,java.lang.String> properties)
Set a collection of properties on a namespace in the catalog.
|
buildTable, buildView, loadViewfullTableName, isValidIdentifier, loadTable, metricsReporter, registerTable, toStringclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitcreateNamespace, listNamespaces, namespaceExistsinvalidateView, viewExistscreateTable, createTable, createTable, createTable, dropTable, invalidateTable, newCreateTableTransaction, newCreateTableTransaction, newCreateTableTransaction, newCreateTableTransaction, newReplaceTableTransaction, newReplaceTableTransaction, newReplaceTableTransaction, newReplaceTableTransaction, tableExistspublic void initialize(java.lang.String name,
java.util.Map<java.lang.String,java.lang.String> options)
ViewCatalogA custom view catalog implementation must have a no-arg constructor. A compute engine like Spark or Flink will first initialize the catalog without any arguments, and then call this method to complete catalog initialization with properties passed into the engine.
initialize in interface Cataloginitialize in interface ViewCataloginitialize in class BaseMetastoreViewCatalogname - a custom name for the catalogoptions - catalog propertiespublic void initialize(java.lang.String name,
NessieIcebergClient client,
FileIO fileIO,
java.util.Map<java.lang.String,java.lang.String> catalogOptions)
NessieIcebergClient
and FileIO instance.name - The name of the catalog, defaults to "nessie" if nullclient - The pre-configured NessieIcebergClient instance to usefileIO - The FileIO instance to usecatalogOptions - The catalog options to usepublic void close()
throws java.io.IOException
close in interface java.io.Closeableclose in interface java.lang.AutoCloseableclose in class BaseMetastoreCatalogjava.io.IOExceptionpublic java.lang.String name()
ViewCatalogname in interface Catalogname in interface ViewCatalogname in class BaseMetastoreViewCatalogprotected TableOperations newTableOps(TableIdentifier tableIdentifier)
newTableOps in class BaseMetastoreCatalogprotected java.lang.String defaultWarehouseLocation(TableIdentifier table)
defaultWarehouseLocation in class BaseMetastoreCatalogpublic java.util.List<TableIdentifier> listTables(Namespace namespace)
CataloglistTables in interface Catalognamespace - a namespacepublic boolean dropTable(TableIdentifier identifier, boolean purge)
CatalogIf purge is set to true the implementation should delete all data and metadata files.
public void renameTable(TableIdentifier from, TableIdentifier to)
CatalogrenameTable in interface Catalogfrom - identifier of the table to renameto - new table namepublic void createNamespace(Namespace namespace, java.util.Map<java.lang.String,java.lang.String> metadata)
SupportsNamespacescreateNamespace in interface SupportsNamespacesnamespace - a multi-part namespacemetadata - a string Map of properties for the given namespacepublic java.util.List<Namespace> listNamespaces(Namespace namespace) throws NoSuchNamespaceException
SupportsNamespacesFor two existing tables named 'a.b.c.table' and 'a.b.d.table', this method returns:
Namespace.empty()
Namespace.of("a")
Namespace.of("a")
Namespace.of("a", "b")
Namespace.of("a", "b")
Namespace.of("a", "b", "c") and Namespace.of("a", "b", "d")
Namespace.of("a", "b", "c")
listNamespaces in interface SupportsNamespacesNamespace names from the given namespaceNoSuchNamespaceException - If the namespace does not exist (optional)public java.util.Map<java.lang.String,java.lang.String> loadNamespaceMetadata(Namespace namespace) throws NoSuchNamespaceException
loadNamespaceMetadata in interface SupportsNamespacesnamespace - a namespace. NamespaceNoSuchNamespaceException - If the namespace does not existpublic boolean dropNamespace(Namespace namespace) throws NamespaceNotEmptyException
SupportsNamespacesdropNamespace in interface SupportsNamespacesnamespace - a namespace. NamespaceNamespaceNotEmptyException - If the namespace is not emptypublic boolean setProperties(Namespace namespace, java.util.Map<java.lang.String,java.lang.String> properties)
SupportsNamespacesProperties that are not in the given map are not modified or removed by this method.
setProperties in interface SupportsNamespacesnamespace - a namespace. Namespaceproperties - a collection of metadata to apply to the namespacepublic boolean removeProperties(Namespace namespace, java.util.Set<java.lang.String> properties)
SupportsNamespacesProperties that are not in the given set are not modified or removed by this method.
removeProperties in interface SupportsNamespacesnamespace - a namespace. Namespaceproperties - a collection of metadata to apply to the namespacepublic void setConf(java.lang.Object conf)
setConf in interface Configurable<java.lang.Object>protected java.util.Map<java.lang.String,java.lang.String> properties()
properties in class BaseMetastoreCatalogprotected ViewOperations newViewOps(TableIdentifier identifier)
newViewOps in class BaseMetastoreViewCatalogpublic java.util.List<TableIdentifier> listViews(Namespace namespace)
ViewCataloglistViews in interface ViewCatalognamespace - a namespacepublic boolean dropView(TableIdentifier identifier)
ViewCatalogdropView in interface ViewCatalogidentifier - a view identifierpublic void renameView(TableIdentifier from, TableIdentifier to)
ViewCatalogrenameView in interface ViewCatalogfrom - identifier of the view to renameto - new view identifier