/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include namespace Aws { namespace Glue { namespace Model { /** */ class AWS_GLUE_API CreateTableRequest : public GlueRequest { public: 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::String SerializePayload() const override; Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; /** *

The ID of the Data Catalog in which to create the Table. If none * is supplied, the AWS 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 AWS 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 AWS 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 AWS 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 AWS 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 AWS 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 AWS 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 AWS 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;} private: Aws::String m_catalogId; bool m_catalogIdHasBeenSet; Aws::String m_databaseName; bool m_databaseNameHasBeenSet; TableInput m_tableInput; bool m_tableInputHasBeenSet; }; } // namespace Model } // namespace Glue } // namespace Aws