Class CfnTable
- All Implemented Interfaces:
IConstruct
,IDependable
,IInspectable
,software.amazon.jsii.JsiiSerializable
,software.constructs.IConstruct
AWS::DynamoDB::Table
.
The AWS::DynamoDB::Table
resource creates a DynamoDB table. For more information, see CreateTable in the Amazon DynamoDB API Reference .
You should be aware of the following behaviors when working with DynamoDB tables:
- AWS CloudFormation typically creates DynamoDB tables in parallel. However, if your template includes multiple DynamoDB tables with indexes, you must declare dependencies so that the tables are created sequentially. Amazon DynamoDB limits the number of tables with secondary indexes that are in the creating state. If you create multiple tables with indexes at the same time, DynamoDB returns an error and the stack operation fails. For an example, see DynamoDB Table with a DependsOn Attribute .
Our guidance is to use the latest schema documented here for your AWS CloudFormation templates. This schema supports the provisioning of all table settings below. When using this schema in your AWS CloudFormation templates, please ensure that your Identity and Access Management ( IAM ) policies are updated with appropriate permissions to allow for the authorization of these setting changes.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import software.amazon.awscdk.services.dynamodb.*; CfnTable cfnTable = CfnTable.Builder.create(this, "MyCfnTable") .keySchema(List.of(KeySchemaProperty.builder() .attributeName("attributeName") .keyType("keyType") .build())) // the properties below are optional .attributeDefinitions(List.of(AttributeDefinitionProperty.builder() .attributeName("attributeName") .attributeType("attributeType") .build())) .billingMode("billingMode") .contributorInsightsSpecification(ContributorInsightsSpecificationProperty.builder() .enabled(false) .build()) .deletionProtectionEnabled(false) .globalSecondaryIndexes(List.of(GlobalSecondaryIndexProperty.builder() .indexName("indexName") .keySchema(List.of(KeySchemaProperty.builder() .attributeName("attributeName") .keyType("keyType") .build())) .projection(ProjectionProperty.builder() .nonKeyAttributes(List.of("nonKeyAttributes")) .projectionType("projectionType") .build()) // the properties below are optional .contributorInsightsSpecification(ContributorInsightsSpecificationProperty.builder() .enabled(false) .build()) .provisionedThroughput(ProvisionedThroughputProperty.builder() .readCapacityUnits(123) .writeCapacityUnits(123) .build()) .build())) .importSourceSpecification(ImportSourceSpecificationProperty.builder() .inputFormat("inputFormat") .s3BucketSource(S3BucketSourceProperty.builder() .s3Bucket("s3Bucket") // the properties below are optional .s3BucketOwner("s3BucketOwner") .s3KeyPrefix("s3KeyPrefix") .build()) // the properties below are optional .inputCompressionType("inputCompressionType") .inputFormatOptions(InputFormatOptionsProperty.builder() .csv(CsvProperty.builder() .delimiter("delimiter") .headerList(List.of("headerList")) .build()) .build()) .build()) .kinesisStreamSpecification(KinesisStreamSpecificationProperty.builder() .streamArn("streamArn") .build()) .localSecondaryIndexes(List.of(LocalSecondaryIndexProperty.builder() .indexName("indexName") .keySchema(List.of(KeySchemaProperty.builder() .attributeName("attributeName") .keyType("keyType") .build())) .projection(ProjectionProperty.builder() .nonKeyAttributes(List.of("nonKeyAttributes")) .projectionType("projectionType") .build()) .build())) .pointInTimeRecoverySpecification(PointInTimeRecoverySpecificationProperty.builder() .pointInTimeRecoveryEnabled(false) .build()) .provisionedThroughput(ProvisionedThroughputProperty.builder() .readCapacityUnits(123) .writeCapacityUnits(123) .build()) .sseSpecification(SSESpecificationProperty.builder() .sseEnabled(false) // the properties below are optional .kmsMasterKeyId("kmsMasterKeyId") .sseType("sseType") .build()) .streamSpecification(StreamSpecificationProperty.builder() .streamViewType("streamViewType") .build()) .tableClass("tableClass") .tableName("tableName") .tags(List.of(CfnTag.builder() .key("key") .value("value") .build())) .timeToLiveSpecification(TimeToLiveSpecificationProperty.builder() .attributeName("attributeName") .enabled(false) .build()) .build();
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic interface
Represents an attribute for describing the key schema for the table and indexes.static final class
A fluent builder forCfnTable
.static interface
The settings used to enable or disable CloudWatch Contributor Insights.static interface
The options for imported source files in CSV format.static interface
Represents the properties of a global secondary index.static interface
Specifies the properties of data being imported from the S3 bucket source to the table.static interface
The format options for the data that was imported into the target table.static interface
Represents a single element of a key schema.static interface
The Kinesis Data Streams configuration for the specified table.static interface
Represents the properties of a local secondary index.static interface
The settings used to enable point in time recovery.static interface
Represents attributes that are copied (projected) from the table into an index.static interface
Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.static interface
The S3 bucket that is being imported from.static interface
Represents the settings used to enable server-side encryption.static interface
Represents the DynamoDB Streams configuration for a table in DynamoDB.static interface
Represents the settings used to enable or disable Time to Live (TTL) for the specified table.Nested classes/interfaces inherited from class software.amazon.jsii.JsiiObject
software.amazon.jsii.JsiiObject.InitializationMode
Nested classes/interfaces inherited from interface software.amazon.awscdk.core.IConstruct
IConstruct.Jsii$Default
Nested classes/interfaces inherited from interface software.constructs.IConstruct
software.constructs.IConstruct.Jsii$Default
Nested classes/interfaces inherited from interface software.amazon.awscdk.core.IInspectable
IInspectable.Jsii$Default, IInspectable.Jsii$Proxy
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
The CloudFormation resource type name for this resource class. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionThe Amazon Resource Name (ARN) of the DynamoDB table, such asarn:aws:dynamodb:us-east-2:123456789012:table/myDynamoDBTable
.A list of attributes that describe the key schema for the table and indexes.The ARN of the DynamoDB stream, such asarn:aws:dynamodb:us-east-1:123456789012:table/testddbstack-myDynamoDBTable-012A1SL7SMP5Q/stream/2015-11-30T20:10:00.000
.Specify how you are charged for read and write throughput and how you manage capacity.The settings used to enable or disable CloudWatch Contributor Insights for the specified table.Determines if a table is protected from deletion.Global secondary indexes to be created on the table.Specifies the properties of data being imported from the S3 bucket source to the table.Specifies the attributes that make up the primary key for the table.The Kinesis Data Streams configuration for the specified table.Local secondary indexes to be created on the table.The settings used to enable point in time recovery.Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.Specifies the settings to enable server-side encryption.The settings for the DynamoDB table stream, which capture changes to items stored in the table.The table class of the new table.A name for the table.getTags()
An array of key-value pairs to apply to this resource.Specifies the Time to Live (TTL) settings for the table.void
inspect
(TreeInspector inspector) Examines the CloudFormation resource and discloses attributes.renderProperties
(Map<String, Object> props) void
setAttributeDefinitions
(List<Object> value) A list of attributes that describe the key schema for the table and indexes.void
A list of attributes that describe the key schema for the table and indexes.void
setBillingMode
(String value) Specify how you are charged for read and write throughput and how you manage capacity.void
The settings used to enable or disable CloudWatch Contributor Insights for the specified table.void
The settings used to enable or disable CloudWatch Contributor Insights for the specified table.void
Determines if a table is protected from deletion.void
Determines if a table is protected from deletion.void
setGlobalSecondaryIndexes
(List<Object> value) Global secondary indexes to be created on the table.void
Global secondary indexes to be created on the table.void
Specifies the properties of data being imported from the S3 bucket source to the table.void
Specifies the properties of data being imported from the S3 bucket source to the table.void
setKeySchema
(List<Object> value) Specifies the attributes that make up the primary key for the table.void
setKeySchema
(IResolvable value) Specifies the attributes that make up the primary key for the table.void
The Kinesis Data Streams configuration for the specified table.void
The Kinesis Data Streams configuration for the specified table.void
setLocalSecondaryIndexes
(List<Object> value) Local secondary indexes to be created on the table.void
Local secondary indexes to be created on the table.void
The settings used to enable point in time recovery.void
The settings used to enable point in time recovery.void
Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.void
Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.void
setSseSpecification
(IResolvable value) Specifies the settings to enable server-side encryption.void
Specifies the settings to enable server-side encryption.void
The settings for the DynamoDB table stream, which capture changes to items stored in the table.void
The settings for the DynamoDB table stream, which capture changes to items stored in the table.void
setTableClass
(String value) The table class of the new table.void
setTableName
(String value) A name for the table.void
Specifies the Time to Live (TTL) settings for the table.void
Specifies the Time to Live (TTL) settings for the table.Methods inherited from class software.amazon.awscdk.core.CfnResource
addDeletionOverride, addDependsOn, addMetadata, addOverride, addPropertyDeletionOverride, addPropertyOverride, applyRemovalPolicy, applyRemovalPolicy, applyRemovalPolicy, getAtt, getCfnOptions, getCfnResourceType, getMetadata, getUpdatedProperites, isCfnResource, shouldSynthesize, toString, validateProperties
Methods inherited from class software.amazon.awscdk.core.CfnRefElement
getRef
Methods inherited from class software.amazon.awscdk.core.CfnElement
getCreationStack, getLogicalId, getStack, isCfnElement, overrideLogicalId
Methods inherited from class software.amazon.awscdk.core.Construct
getNode, isConstruct, onPrepare, onSynthesize, onValidate, prepare, synthesize, validate
Methods inherited from class software.amazon.jsii.JsiiObject
jsiiAsyncCall, jsiiAsyncCall, jsiiCall, jsiiCall, jsiiGet, jsiiGet, jsiiSet, jsiiStaticCall, jsiiStaticCall, jsiiStaticGet, jsiiStaticGet, jsiiStaticSet, jsiiStaticSet
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface software.amazon.jsii.JsiiSerializable
$jsii$toJson
-
Field Details
-
CFN_RESOURCE_TYPE_NAME
The CloudFormation resource type name for this resource class.
-
-
Constructor Details
-
CfnTable
protected CfnTable(software.amazon.jsii.JsiiObjectRef objRef) -
CfnTable
protected CfnTable(software.amazon.jsii.JsiiObject.InitializationMode initializationMode) -
CfnTable
@Stability(Stable) public CfnTable(@NotNull Construct scope, @NotNull String id, @NotNull CfnTableProps props) Create a newAWS::DynamoDB::Table
.- Parameters:
scope
-- scope in which this resource is defined.
id
-- scoped id of the resource.
props
-- resource properties.
-
-
Method Details
-
inspect
Examines the CloudFormation resource and discloses attributes.- Specified by:
inspect
in interfaceIInspectable
- Parameters:
inspector
-- tree inspector to collect and process attributes.
-
renderProperties
@Stability(Stable) @NotNull protected Map<String,Object> renderProperties(@NotNull Map<String, Object> props) - Overrides:
renderProperties
in classCfnResource
- Parameters:
props
- This parameter is required.
-
getAttrArn
The Amazon Resource Name (ARN) of the DynamoDB table, such asarn:aws:dynamodb:us-east-2:123456789012:table/myDynamoDBTable
. -
getAttrStreamArn
The ARN of the DynamoDB stream, such asarn:aws:dynamodb:us-east-1:123456789012:table/testddbstack-myDynamoDBTable-012A1SL7SMP5Q/stream/2015-11-30T20:10:00.000
.You must specify the
StreamSpecification
property to use this attribute. -
getCfnProperties
- Overrides:
getCfnProperties
in classCfnResource
-
getTags
An array of key-value pairs to apply to this resource.For more information, see Tag .
-
getKeySchema
Specifies the attributes that make up the primary key for the table.The attributes in the
KeySchema
property must also be defined in theAttributeDefinitions
property. -
setKeySchema
Specifies the attributes that make up the primary key for the table.The attributes in the
KeySchema
property must also be defined in theAttributeDefinitions
property. -
setKeySchema
Specifies the attributes that make up the primary key for the table.The attributes in the
KeySchema
property must also be defined in theAttributeDefinitions
property. -
getAttributeDefinitions
A list of attributes that describe the key schema for the table and indexes.This property is required to create a DynamoDB table.
Update requires: Some interruptions . Replacement if you edit an existing AttributeDefinition.
-
setAttributeDefinitions
A list of attributes that describe the key schema for the table and indexes.This property is required to create a DynamoDB table.
Update requires: Some interruptions . Replacement if you edit an existing AttributeDefinition.
-
setAttributeDefinitions
A list of attributes that describe the key schema for the table and indexes.This property is required to create a DynamoDB table.
Update requires: Some interruptions . Replacement if you edit an existing AttributeDefinition.
-
getBillingMode
Specify how you are charged for read and write throughput and how you manage capacity.Valid values include:
PROVISIONED
- We recommend usingPROVISIONED
for predictable workloads.PROVISIONED
sets the billing mode to Provisioned Mode .PAY_PER_REQUEST
- We recommend usingPAY_PER_REQUEST
for unpredictable workloads.PAY_PER_REQUEST
sets the billing mode to On-Demand Mode .
If not specified, the default is
PROVISIONED
. -
setBillingMode
Specify how you are charged for read and write throughput and how you manage capacity.Valid values include:
PROVISIONED
- We recommend usingPROVISIONED
for predictable workloads.PROVISIONED
sets the billing mode to Provisioned Mode .PAY_PER_REQUEST
- We recommend usingPAY_PER_REQUEST
for unpredictable workloads.PAY_PER_REQUEST
sets the billing mode to On-Demand Mode .
If not specified, the default is
PROVISIONED
. -
getContributorInsightsSpecification
The settings used to enable or disable CloudWatch Contributor Insights for the specified table. -
setContributorInsightsSpecification
The settings used to enable or disable CloudWatch Contributor Insights for the specified table. -
setContributorInsightsSpecification
@Stability(Stable) public void setContributorInsightsSpecification(@Nullable CfnTable.ContributorInsightsSpecificationProperty value) The settings used to enable or disable CloudWatch Contributor Insights for the specified table. -
getDeletionProtectionEnabled
Determines if a table is protected from deletion.When enabled, the table cannot be deleted by any user or process. This setting is disabled by default. For more information, see Using deletion protection in the Amazon DynamoDB Developer Guide .
-
setDeletionProtectionEnabled
Determines if a table is protected from deletion.When enabled, the table cannot be deleted by any user or process. This setting is disabled by default. For more information, see Using deletion protection in the Amazon DynamoDB Developer Guide .
-
setDeletionProtectionEnabled
Determines if a table is protected from deletion.When enabled, the table cannot be deleted by any user or process. This setting is disabled by default. For more information, see Using deletion protection in the Amazon DynamoDB Developer Guide .
-
getGlobalSecondaryIndexes
Global secondary indexes to be created on the table. You can create up to 20 global secondary indexes.If you update a table to include a new global secondary index, AWS CloudFormation initiates the index creation and then proceeds with the stack update. AWS CloudFormation doesn't wait for the index to complete creation because the backfilling phase can take a long time, depending on the size of the table. You can't use the index or update the table until the index's status is
ACTIVE
. You can track its status by using the DynamoDB DescribeTable command.If you add or delete an index during an update, we recommend that you don't update any other resources. If your stack fails to update and is rolled back while adding a new index, you must manually delete the index.
Updates are not supported. The following are exceptions:
- If you update either the contributor insights specification or the provisioned throughput values of global secondary indexes, you can update the table without interruption.
- You can delete or add one global secondary index without interruption. If you do both in the same update (for example, by changing the index's logical ID), the update fails.
-
setGlobalSecondaryIndexes
Global secondary indexes to be created on the table. You can create up to 20 global secondary indexes.If you update a table to include a new global secondary index, AWS CloudFormation initiates the index creation and then proceeds with the stack update. AWS CloudFormation doesn't wait for the index to complete creation because the backfilling phase can take a long time, depending on the size of the table. You can't use the index or update the table until the index's status is
ACTIVE
. You can track its status by using the DynamoDB DescribeTable command.If you add or delete an index during an update, we recommend that you don't update any other resources. If your stack fails to update and is rolled back while adding a new index, you must manually delete the index.
Updates are not supported. The following are exceptions:
- If you update either the contributor insights specification or the provisioned throughput values of global secondary indexes, you can update the table without interruption.
- You can delete or add one global secondary index without interruption. If you do both in the same update (for example, by changing the index's logical ID), the update fails.
-
setGlobalSecondaryIndexes
Global secondary indexes to be created on the table. You can create up to 20 global secondary indexes.If you update a table to include a new global secondary index, AWS CloudFormation initiates the index creation and then proceeds with the stack update. AWS CloudFormation doesn't wait for the index to complete creation because the backfilling phase can take a long time, depending on the size of the table. You can't use the index or update the table until the index's status is
ACTIVE
. You can track its status by using the DynamoDB DescribeTable command.If you add or delete an index during an update, we recommend that you don't update any other resources. If your stack fails to update and is rolled back while adding a new index, you must manually delete the index.
Updates are not supported. The following are exceptions:
- If you update either the contributor insights specification or the provisioned throughput values of global secondary indexes, you can update the table without interruption.
- You can delete or add one global secondary index without interruption. If you do both in the same update (for example, by changing the index's logical ID), the update fails.
-
getImportSourceSpecification
Specifies the properties of data being imported from the S3 bucket source to the table.If you specify the
ImportSourceSpecification
property, and also specify either theStreamSpecification
, theTableClass
property, or theDeletionProtectionEnabled
property, the IAM entity creating/updating stack must haveUpdateTable
permission. -
setImportSourceSpecification
Specifies the properties of data being imported from the S3 bucket source to the table.If you specify the
ImportSourceSpecification
property, and also specify either theStreamSpecification
, theTableClass
property, or theDeletionProtectionEnabled
property, the IAM entity creating/updating stack must haveUpdateTable
permission. -
setImportSourceSpecification
@Stability(Stable) public void setImportSourceSpecification(@Nullable CfnTable.ImportSourceSpecificationProperty value) Specifies the properties of data being imported from the S3 bucket source to the table.If you specify the
ImportSourceSpecification
property, and also specify either theStreamSpecification
, theTableClass
property, or theDeletionProtectionEnabled
property, the IAM entity creating/updating stack must haveUpdateTable
permission. -
getKinesisStreamSpecification
The Kinesis Data Streams configuration for the specified table. -
setKinesisStreamSpecification
The Kinesis Data Streams configuration for the specified table. -
setKinesisStreamSpecification
@Stability(Stable) public void setKinesisStreamSpecification(@Nullable CfnTable.KinesisStreamSpecificationProperty value) The Kinesis Data Streams configuration for the specified table. -
getLocalSecondaryIndexes
Local secondary indexes to be created on the table.You can create up to 5 local secondary indexes. Each index is scoped to a given hash key value. The size of each hash key can be up to 10 gigabytes.
-
setLocalSecondaryIndexes
Local secondary indexes to be created on the table.You can create up to 5 local secondary indexes. Each index is scoped to a given hash key value. The size of each hash key can be up to 10 gigabytes.
-
setLocalSecondaryIndexes
Local secondary indexes to be created on the table.You can create up to 5 local secondary indexes. Each index is scoped to a given hash key value. The size of each hash key can be up to 10 gigabytes.
-
getPointInTimeRecoverySpecification
The settings used to enable point in time recovery. -
setPointInTimeRecoverySpecification
The settings used to enable point in time recovery. -
setPointInTimeRecoverySpecification
@Stability(Stable) public void setPointInTimeRecoverySpecification(@Nullable CfnTable.PointInTimeRecoverySpecificationProperty value) The settings used to enable point in time recovery. -
getProvisionedThroughput
Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.For more information about the contents of a provisioned throughput structure, see Amazon DynamoDB Table ProvisionedThroughput .
If you set
BillingMode
asPROVISIONED
, you must specify this property. If you setBillingMode
asPAY_PER_REQUEST
, you cannot specify this property. -
setProvisionedThroughput
Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.For more information about the contents of a provisioned throughput structure, see Amazon DynamoDB Table ProvisionedThroughput .
If you set
BillingMode
asPROVISIONED
, you must specify this property. If you setBillingMode
asPAY_PER_REQUEST
, you cannot specify this property. -
setProvisionedThroughput
@Stability(Stable) public void setProvisionedThroughput(@Nullable CfnTable.ProvisionedThroughputProperty value) Throughput for the specified table, which consists of values forReadCapacityUnits
andWriteCapacityUnits
.For more information about the contents of a provisioned throughput structure, see Amazon DynamoDB Table ProvisionedThroughput .
If you set
BillingMode
asPROVISIONED
, you must specify this property. If you setBillingMode
asPAY_PER_REQUEST
, you cannot specify this property. -
getSseSpecification
Specifies the settings to enable server-side encryption. -
setSseSpecification
Specifies the settings to enable server-side encryption. -
setSseSpecification
@Stability(Stable) public void setSseSpecification(@Nullable CfnTable.SSESpecificationProperty value) Specifies the settings to enable server-side encryption. -
getStreamSpecification
The settings for the DynamoDB table stream, which capture changes to items stored in the table. -
setStreamSpecification
The settings for the DynamoDB table stream, which capture changes to items stored in the table. -
setStreamSpecification
@Stability(Stable) public void setStreamSpecification(@Nullable CfnTable.StreamSpecificationProperty value) The settings for the DynamoDB table stream, which capture changes to items stored in the table. -
getTableClass
The table class of the new table.Valid values are
STANDARD
andSTANDARD_INFREQUENT_ACCESS
. -
setTableClass
The table class of the new table.Valid values are
STANDARD
andSTANDARD_INFREQUENT_ACCESS
. -
getTableName
A name for the table.If you don't specify a name, AWS CloudFormation generates a unique physical ID and uses that ID for the table name. For more information, see Name Type .
If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name.
-
setTableName
A name for the table.If you don't specify a name, AWS CloudFormation generates a unique physical ID and uses that ID for the table name. For more information, see Name Type .
If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name.
-
getTimeToLiveSpecification
Specifies the Time to Live (TTL) settings for the table.For detailed information about the limits in DynamoDB, see Limits in Amazon DynamoDB in the Amazon DynamoDB Developer Guide.
-
setTimeToLiveSpecification
Specifies the Time to Live (TTL) settings for the table.For detailed information about the limits in DynamoDB, see Limits in Amazon DynamoDB in the Amazon DynamoDB Developer Guide.
-
setTimeToLiveSpecification
@Stability(Stable) public void setTimeToLiveSpecification(@Nullable CfnTable.TimeToLiveSpecificationProperty value) Specifies the Time to Live (TTL) settings for the table.For detailed information about the limits in DynamoDB, see Limits in Amazon DynamoDB in the Amazon DynamoDB Developer Guide.
-