Interface SupportsNamespaces
- 
- All Known Implementing Classes:
- DynamoDbCatalog,- GlueCatalog,- HadoopCatalog,- HiveCatalog,- JdbcCatalog,- NessieCatalog
 
 public interface SupportsNamespacesCatalog methods for working with namespaces.If an object such as a table, view, or function exists, its parent namespaces must also exist and must be returned by the discovery methods listNamespaces()andlistNamespaces(Namespace namespace).Catalog implementations are not required to maintain the existence of namespaces independent of objects in a namespace. For example, a function catalog that loads functions using reflection and uses Java packages as namespaces is not required to support the methods to create, alter, or drop a namespace. Implementations are allowed to discover the existence of objects or namespaces without throwing NoSuchNamespaceExceptionwhen no namespace is found.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description default voidcreateNamespace(Namespace namespace)Create a namespace in the catalog.voidcreateNamespace(Namespace namespace, java.util.Map<java.lang.String,java.lang.String> metadata)Create a namespace in the catalog.booleandropNamespace(Namespace namespace)Drop a namespace.default java.util.List<Namespace>listNamespaces()List top-level namespaces from the catalog.java.util.List<Namespace>listNamespaces(Namespace namespace)List namespaces from the namespace.java.util.Map<java.lang.String,java.lang.String>loadNamespaceMetadata(Namespace namespace)Load metadata properties for a namespace.default booleannamespaceExists(Namespace namespace)Checks whether the Namespace exists.booleanremoveProperties(Namespace namespace, java.util.Set<java.lang.String> properties)Remove a set of metadata from a namespace in the catalog.booleansetProperties(Namespace namespace, java.util.Map<java.lang.String,java.lang.String> properties)Apply a set of metadata to a namespace in the catalog.
 
- 
- 
- 
Method Detail- 
createNamespacedefault void createNamespace(Namespace namespace) Create a namespace in the catalog.- Parameters:
- namespace- a namespace.- Namespace.
- Throws:
- AlreadyExistsException- If the namespace already exists
- java.lang.UnsupportedOperationException- If create is not a supported operation
 
 - 
createNamespacevoid createNamespace(Namespace namespace, java.util.Map<java.lang.String,java.lang.String> metadata) Create a namespace in the catalog.- Parameters:
- namespace- a multi-part namespace
- metadata- a string Map of properties for the given namespace
- Throws:
- AlreadyExistsException- If the namespace already exists
- java.lang.UnsupportedOperationException- If create is not a supported operation
 
 - 
listNamespacesdefault java.util.List<Namespace> listNamespaces() List top-level namespaces from the catalog.If an object such as a table, view, or function exists, its parent namespaces must also exist and must be returned by this discovery method. For example, if table a.b.t exists, this method must return ["a"] in the result array. - Returns:
- an List of namespace Namespacenames
 
 - 
listNamespacesjava.util.List<Namespace> listNamespaces(Namespace namespace) throws NoSuchNamespaceException List namespaces from the namespace.For example, if table a.b.t exists, use 'SELECT NAMESPACE IN a' this method must return Namepace.of("a","b") Namespace.- Returns:
- a List of namespace Namespacenames
- Throws:
- NoSuchNamespaceException- If the namespace does not exist (optional)
 
 - 
loadNamespaceMetadatajava.util.Map<java.lang.String,java.lang.String> loadNamespaceMetadata(Namespace namespace) throws NoSuchNamespaceException Load metadata properties for a namespace.- Parameters:
- namespace- a namespace.- Namespace
- Returns:
- a string map of properties for the given namespace
- Throws:
- NoSuchNamespaceException- If the namespace does not exist (optional)
 
 - 
dropNamespaceboolean dropNamespace(Namespace namespace) throws NamespaceNotEmptyException Drop a namespace. If the namespace exists and was dropped, this will return true.- Parameters:
- namespace- a namespace.- Namespace
- Returns:
- true if the namespace was dropped, false otherwise.
- Throws:
- NamespaceNotEmptyException- If the namespace does not empty
 
 - 
setPropertiesboolean setProperties(Namespace namespace, java.util.Map<java.lang.String,java.lang.String> properties) throws NoSuchNamespaceException Apply a set of metadata to a namespace in the catalog.- Parameters:
- namespace- a namespace.- Namespace
- properties- a collection of metadata to apply to the namespace
- Throws:
- NoSuchNamespaceException- If the namespace does not exist (optional)
- java.lang.UnsupportedOperationException- If namespace properties are not supported
 
 - 
removePropertiesboolean removeProperties(Namespace namespace, java.util.Set<java.lang.String> properties) throws NoSuchNamespaceException Remove a set of metadata from a namespace in the catalog.- Parameters:
- namespace- a namespace.- Namespace
- properties- a collection of metadata to apply to the namespace
- Throws:
- NoSuchNamespaceException- If the namespace does not exist (optional)
- java.lang.UnsupportedOperationException- If namespace properties are not supported
 
 
- 
 
-