/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include #include #include namespace Aws { namespace Glue { namespace Model { /** */ class CreateTableRequest : public GlueRequest { public: AWS_GLUE_API CreateTableRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "CreateTable"; } AWS_GLUE_API Aws::String SerializePayload() const override; AWS_GLUE_API Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline const Aws::String& GetCatalogId() const{ return m_catalogId; } /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline bool CatalogIdHasBeenSet() const { return m_catalogIdHasBeenSet; } /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline void SetCatalogId(const Aws::String& value) { m_catalogIdHasBeenSet = true; m_catalogId = value; } /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline void SetCatalogId(Aws::String&& value) { m_catalogIdHasBeenSet = true; m_catalogId = std::move(value); } /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline void SetCatalogId(const char* value) { m_catalogIdHasBeenSet = true; m_catalogId.assign(value); } /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline CreateTableRequest& WithCatalogId(const Aws::String& value) { SetCatalogId(value); return *this;} /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline CreateTableRequest& WithCatalogId(Aws::String&& value) { SetCatalogId(std::move(value)); return *this;} /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the Amazon Web Services account ID is used by default.

*/ inline CreateTableRequest& WithCatalogId(const char* value) { SetCatalogId(value); return *this;} /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline const Aws::String& GetDatabaseName() const{ return m_databaseName; } /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline bool DatabaseNameHasBeenSet() const { return m_databaseNameHasBeenSet; } /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline void SetDatabaseName(const Aws::String& value) { m_databaseNameHasBeenSet = true; m_databaseName = value; } /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline void SetDatabaseName(Aws::String&& value) { m_databaseNameHasBeenSet = true; m_databaseName = std::move(value); } /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline void SetDatabaseName(const char* value) { m_databaseNameHasBeenSet = true; m_databaseName.assign(value); } /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline CreateTableRequest& WithDatabaseName(const Aws::String& value) { SetDatabaseName(value); return *this;} /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline CreateTableRequest& WithDatabaseName(Aws::String&& value) { SetDatabaseName(std::move(value)); return *this;} /** *

The catalog database in which to create the new table. For Hive * compatibility, this name is entirely lowercase.

*/ inline CreateTableRequest& WithDatabaseName(const char* value) { SetDatabaseName(value); return *this;} /** *

The TableInput object that defines the metadata table to create * in the catalog.

*/ inline const TableInput& GetTableInput() const{ return m_tableInput; } /** *

The TableInput object that defines the metadata table to create * in the catalog.

*/ inline bool TableInputHasBeenSet() const { return m_tableInputHasBeenSet; } /** *

The TableInput object that defines the metadata table to create * in the catalog.

*/ inline void SetTableInput(const TableInput& value) { m_tableInputHasBeenSet = true; m_tableInput = value; } /** *

The TableInput object that defines the metadata table to create * in the catalog.

*/ inline void SetTableInput(TableInput&& value) { m_tableInputHasBeenSet = true; m_tableInput = std::move(value); } /** *

The TableInput object that defines the metadata table to create * in the catalog.

*/ inline CreateTableRequest& WithTableInput(const TableInput& value) { SetTableInput(value); return *this;} /** *

The TableInput object that defines the metadata table to create * in the catalog.

*/ inline CreateTableRequest& WithTableInput(TableInput&& value) { SetTableInput(std::move(value)); return *this;} /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline const Aws::Vector& GetPartitionIndexes() const{ return m_partitionIndexes; } /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline bool PartitionIndexesHasBeenSet() const { return m_partitionIndexesHasBeenSet; } /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline void SetPartitionIndexes(const Aws::Vector& value) { m_partitionIndexesHasBeenSet = true; m_partitionIndexes = value; } /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline void SetPartitionIndexes(Aws::Vector&& value) { m_partitionIndexesHasBeenSet = true; m_partitionIndexes = std::move(value); } /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline CreateTableRequest& WithPartitionIndexes(const Aws::Vector& value) { SetPartitionIndexes(value); return *this;} /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline CreateTableRequest& WithPartitionIndexes(Aws::Vector&& value) { SetPartitionIndexes(std::move(value)); return *this;} /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline CreateTableRequest& AddPartitionIndexes(const PartitionIndex& value) { m_partitionIndexesHasBeenSet = true; m_partitionIndexes.push_back(value); return *this; } /** *

A list of partition indexes, PartitionIndex structures, to * create in the table.

*/ inline CreateTableRequest& AddPartitionIndexes(PartitionIndex&& value) { m_partitionIndexesHasBeenSet = true; m_partitionIndexes.push_back(std::move(value)); return *this; } /** *

The ID of the transaction.

*/ inline const Aws::String& GetTransactionId() const{ return m_transactionId; } /** *

The ID of the transaction.

*/ inline bool TransactionIdHasBeenSet() const { return m_transactionIdHasBeenSet; } /** *

The ID of the transaction.

*/ inline void SetTransactionId(const Aws::String& value) { m_transactionIdHasBeenSet = true; m_transactionId = value; } /** *

The ID of the transaction.

*/ inline void SetTransactionId(Aws::String&& value) { m_transactionIdHasBeenSet = true; m_transactionId = std::move(value); } /** *

The ID of the transaction.

*/ inline void SetTransactionId(const char* value) { m_transactionIdHasBeenSet = true; m_transactionId.assign(value); } /** *

The ID of the transaction.

*/ inline CreateTableRequest& WithTransactionId(const Aws::String& value) { SetTransactionId(value); return *this;} /** *

The ID of the transaction.

*/ inline CreateTableRequest& WithTransactionId(Aws::String&& value) { SetTransactionId(std::move(value)); return *this;} /** *

The ID of the transaction.

*/ inline CreateTableRequest& WithTransactionId(const char* value) { SetTransactionId(value); return *this;} /** *

Specifies an OpenTableFormatInput structure when creating an * open format table.

*/ inline const OpenTableFormatInput& GetOpenTableFormatInput() const{ return m_openTableFormatInput; } /** *

Specifies an OpenTableFormatInput structure when creating an * open format table.

*/ inline bool OpenTableFormatInputHasBeenSet() const { return m_openTableFormatInputHasBeenSet; } /** *

Specifies an OpenTableFormatInput structure when creating an * open format table.

*/ inline void SetOpenTableFormatInput(const OpenTableFormatInput& value) { m_openTableFormatInputHasBeenSet = true; m_openTableFormatInput = value; } /** *

Specifies an OpenTableFormatInput structure when creating an * open format table.

*/ inline void SetOpenTableFormatInput(OpenTableFormatInput&& value) { m_openTableFormatInputHasBeenSet = true; m_openTableFormatInput = std::move(value); } /** *

Specifies an OpenTableFormatInput structure when creating an * open format table.

*/ inline CreateTableRequest& WithOpenTableFormatInput(const OpenTableFormatInput& value) { SetOpenTableFormatInput(value); return *this;} /** *

Specifies an OpenTableFormatInput structure when creating an * open format table.

*/ inline CreateTableRequest& WithOpenTableFormatInput(OpenTableFormatInput&& value) { SetOpenTableFormatInput(std::move(value)); return *this;} private: Aws::String m_catalogId; bool m_catalogIdHasBeenSet = false; Aws::String m_databaseName; bool m_databaseNameHasBeenSet = false; TableInput m_tableInput; bool m_tableInputHasBeenSet = false; Aws::Vector m_partitionIndexes; bool m_partitionIndexesHasBeenSet = false; Aws::String m_transactionId; bool m_transactionIdHasBeenSet = false; OpenTableFormatInput m_openTableFormatInput; bool m_openTableFormatInputHasBeenSet = false; }; } // namespace Model } // namespace Glue } // namespace Aws