All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.databricks.sdk.service.catalog.TablesAPI Maven / Gradle / Ivy

// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.catalog;

import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.Paginator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * A table resides in the third layer of Unity Catalog’s three-level namespace. It contains rows of
 * data. To create a table, users must have CREATE_TABLE and USE_SCHEMA permissions on the schema,
 * and they must have the USE_CATALOG permission on its parent catalog. To query a table, users must
 * have the SELECT permission on the table, and they must have the USE_CATALOG permission on its
 * parent catalog and the USE_SCHEMA permission on its parent schema.
 *
 * 

A table can be managed or external. From an API perspective, a __VIEW__ is a particular kind * of table (rather than a managed or external table). */ @Generated public class TablesAPI { private static final Logger LOG = LoggerFactory.getLogger(TablesAPI.class); private final TablesService impl; /** Regular-use constructor */ public TablesAPI(ApiClient apiClient) { impl = new TablesImpl(apiClient); } /** Constructor for mocks */ public TablesAPI(TablesService mock) { impl = mock; } public void delete(String fullName) { delete(new DeleteTableRequest().setFullName(fullName)); } /** * Delete a table. * *

Deletes a table from the specified parent catalog and schema. The caller must be the owner * of the parent catalog, have the **USE_CATALOG** privilege on the parent catalog and be the * owner of the parent schema, or be the owner of the table and have the **USE_CATALOG** privilege * on the parent catalog and the **USE_SCHEMA** privilege on the parent schema. */ public void delete(DeleteTableRequest request) { impl.delete(request); } public TableExistsResponse exists(String fullName) { return exists(new ExistsRequest().setFullName(fullName)); } /** * Get boolean reflecting if table exists. * *

Gets if a table exists in the metastore for a specific catalog and schema. The caller must * satisfy one of the following requirements: * Be a metastore admin * Be the owner of the parent * catalog * Be the owner of the parent schema and have the USE_CATALOG privilege on the parent * catalog * Have the **USE_CATALOG** privilege on the parent catalog and the **USE_SCHEMA** * privilege on the parent schema, and either be the table owner or have the SELECT privilege on * the table. * Have BROWSE privilege on the parent catalog * Have BROWSE privilege on the parent * schema. */ public TableExistsResponse exists(ExistsRequest request) { return impl.exists(request); } public TableInfo get(String fullName) { return get(new GetTableRequest().setFullName(fullName)); } /** * Get a table. * *

Gets a table from the metastore for a specific catalog and schema. The caller must satisfy * one of the following requirements: * Be a metastore admin * Be the owner of the parent catalog * * Be the owner of the parent schema and have the USE_CATALOG privilege on the parent catalog * * Have the **USE_CATALOG** privilege on the parent catalog and the **USE_SCHEMA** privilege on * the parent schema, and either be the table owner or have the SELECT privilege on the table. */ public TableInfo get(GetTableRequest request) { return impl.get(request); } public Iterable list(String catalogName, String schemaName) { return list(new ListTablesRequest().setCatalogName(catalogName).setSchemaName(schemaName)); } /** * List tables. * *

Gets an array of all tables for the current metastore under the parent catalog and schema. * The caller must be a metastore admin or an owner of (or have the **SELECT** privilege on) the * table. For the latter case, the caller must also be the owner or have the **USE_CATALOG** * privilege on the parent catalog and the **USE_SCHEMA** privilege on the parent schema. There is * no guarantee of a specific ordering of the elements in the array. */ public Iterable list(ListTablesRequest request) { return new Paginator<>( request, impl::list, ListTablesResponse::getTables, response -> { String token = response.getNextPageToken(); if (token == null) { return null; } return request.setPageToken(token); }); } public Iterable listSummaries(String catalogName) { return listSummaries(new ListSummariesRequest().setCatalogName(catalogName)); } /** * List table summaries. * *

Gets an array of summaries for tables for a schema and catalog within the metastore. The * table summaries returned are either: * *

* summaries for tables (within the current metastore and parent catalog and schema), when * the user is a metastore admin, or: * summaries for tables and schemas (within the current * metastore and parent catalog) for which the user has ownership or the **SELECT** privilege on * the table and ownership or **USE_SCHEMA** privilege on the schema, provided that the user also * has ownership or the **USE_CATALOG** privilege on the parent catalog. * *

There is no guarantee of a specific ordering of the elements in the array. */ public Iterable listSummaries(ListSummariesRequest request) { return new Paginator<>( request, impl::listSummaries, ListTableSummariesResponse::getTables, response -> { String token = response.getNextPageToken(); if (token == null) { return null; } return request.setPageToken(token); }); } public void update(String fullName) { update(new UpdateTableRequest().setFullName(fullName)); } /** * Update a table owner. * *

Change the owner of the table. The caller must be the owner of the parent catalog, have the * **USE_CATALOG** privilege on the parent catalog and be the owner of the parent schema, or be * the owner of the table and have the **USE_CATALOG** privilege on the parent catalog and the * **USE_SCHEMA** privilege on the parent schema. */ public void update(UpdateTableRequest request) { impl.update(request); } public TablesService impl() { return impl; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy