{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.Glue.DeleteColumnStatisticsForTable -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieves table statistics of columns. -- -- The Identity and Access Management (IAM) permission required for this -- operation is @DeleteTable@. module Amazonka.Glue.DeleteColumnStatisticsForTable ( -- * Creating a Request DeleteColumnStatisticsForTable (..), newDeleteColumnStatisticsForTable, -- * Request Lenses deleteColumnStatisticsForTable_catalogId, deleteColumnStatisticsForTable_databaseName, deleteColumnStatisticsForTable_tableName, deleteColumnStatisticsForTable_columnName, -- * Destructuring the Response DeleteColumnStatisticsForTableResponse (..), newDeleteColumnStatisticsForTableResponse, -- * Response Lenses deleteColumnStatisticsForTableResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Glue.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteColumnStatisticsForTable' smart constructor. data DeleteColumnStatisticsForTable = DeleteColumnStatisticsForTable' { -- | The ID of the Data Catalog where the partitions in question reside. If -- none is supplied, the Amazon Web Services account ID is used by default. catalogId :: Prelude.Maybe Prelude.Text, -- | The name of the catalog database where the partitions reside. databaseName :: Prelude.Text, -- | The name of the partitions\' table. tableName :: Prelude.Text, -- | The name of the column. columnName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteColumnStatisticsForTable' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'catalogId', 'deleteColumnStatisticsForTable_catalogId' - The ID of the Data Catalog where the partitions in question reside. If -- none is supplied, the Amazon Web Services account ID is used by default. -- -- 'databaseName', 'deleteColumnStatisticsForTable_databaseName' - The name of the catalog database where the partitions reside. -- -- 'tableName', 'deleteColumnStatisticsForTable_tableName' - The name of the partitions\' table. -- -- 'columnName', 'deleteColumnStatisticsForTable_columnName' - The name of the column. newDeleteColumnStatisticsForTable :: -- | 'databaseName' Prelude.Text -> -- | 'tableName' Prelude.Text -> -- | 'columnName' Prelude.Text -> DeleteColumnStatisticsForTable newDeleteColumnStatisticsForTable pDatabaseName_ pTableName_ pColumnName_ = DeleteColumnStatisticsForTable' { catalogId = Prelude.Nothing, databaseName = pDatabaseName_, tableName = pTableName_, columnName = pColumnName_ } -- | The ID of the Data Catalog where the partitions in question reside. If -- none is supplied, the Amazon Web Services account ID is used by default. deleteColumnStatisticsForTable_catalogId :: Lens.Lens' DeleteColumnStatisticsForTable (Prelude.Maybe Prelude.Text) deleteColumnStatisticsForTable_catalogId = Lens.lens (\DeleteColumnStatisticsForTable' {catalogId} -> catalogId) (\s@DeleteColumnStatisticsForTable' {} a -> s {catalogId = a} :: DeleteColumnStatisticsForTable) -- | The name of the catalog database where the partitions reside. deleteColumnStatisticsForTable_databaseName :: Lens.Lens' DeleteColumnStatisticsForTable Prelude.Text deleteColumnStatisticsForTable_databaseName = Lens.lens (\DeleteColumnStatisticsForTable' {databaseName} -> databaseName) (\s@DeleteColumnStatisticsForTable' {} a -> s {databaseName = a} :: DeleteColumnStatisticsForTable) -- | The name of the partitions\' table. deleteColumnStatisticsForTable_tableName :: Lens.Lens' DeleteColumnStatisticsForTable Prelude.Text deleteColumnStatisticsForTable_tableName = Lens.lens (\DeleteColumnStatisticsForTable' {tableName} -> tableName) (\s@DeleteColumnStatisticsForTable' {} a -> s {tableName = a} :: DeleteColumnStatisticsForTable) -- | The name of the column. deleteColumnStatisticsForTable_columnName :: Lens.Lens' DeleteColumnStatisticsForTable Prelude.Text deleteColumnStatisticsForTable_columnName = Lens.lens (\DeleteColumnStatisticsForTable' {columnName} -> columnName) (\s@DeleteColumnStatisticsForTable' {} a -> s {columnName = a} :: DeleteColumnStatisticsForTable) instance Core.AWSRequest DeleteColumnStatisticsForTable where type AWSResponse DeleteColumnStatisticsForTable = DeleteColumnStatisticsForTableResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteColumnStatisticsForTableResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteColumnStatisticsForTable where hashWithSalt _salt DeleteColumnStatisticsForTable' {..} = _salt `Prelude.hashWithSalt` catalogId `Prelude.hashWithSalt` databaseName `Prelude.hashWithSalt` tableName `Prelude.hashWithSalt` columnName instance Prelude.NFData DeleteColumnStatisticsForTable where rnf DeleteColumnStatisticsForTable' {..} = Prelude.rnf catalogId `Prelude.seq` Prelude.rnf databaseName `Prelude.seq` Prelude.rnf tableName `Prelude.seq` Prelude.rnf columnName instance Data.ToHeaders DeleteColumnStatisticsForTable where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSGlue.DeleteColumnStatisticsForTable" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteColumnStatisticsForTable where toJSON DeleteColumnStatisticsForTable' {..} = Data.object ( Prelude.catMaybes [ ("CatalogId" Data..=) Prelude.<$> catalogId, Prelude.Just ("DatabaseName" Data..= databaseName), Prelude.Just ("TableName" Data..= tableName), Prelude.Just ("ColumnName" Data..= columnName) ] ) instance Data.ToPath DeleteColumnStatisticsForTable where toPath = Prelude.const "/" instance Data.ToQuery DeleteColumnStatisticsForTable where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteColumnStatisticsForTableResponse' smart constructor. data DeleteColumnStatisticsForTableResponse = DeleteColumnStatisticsForTableResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteColumnStatisticsForTableResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'httpStatus', 'deleteColumnStatisticsForTableResponse_httpStatus' - The response's http status code. newDeleteColumnStatisticsForTableResponse :: -- | 'httpStatus' Prelude.Int -> DeleteColumnStatisticsForTableResponse newDeleteColumnStatisticsForTableResponse pHttpStatus_ = DeleteColumnStatisticsForTableResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. deleteColumnStatisticsForTableResponse_httpStatus :: Lens.Lens' DeleteColumnStatisticsForTableResponse Prelude.Int deleteColumnStatisticsForTableResponse_httpStatus = Lens.lens (\DeleteColumnStatisticsForTableResponse' {httpStatus} -> httpStatus) (\s@DeleteColumnStatisticsForTableResponse' {} a -> s {httpStatus = a} :: DeleteColumnStatisticsForTableResponse) instance Prelude.NFData DeleteColumnStatisticsForTableResponse where rnf DeleteColumnStatisticsForTableResponse' {..} = Prelude.rnf httpStatus