PutItem
Note
We recommend using the DynamoDB built-in module to generate your request. For more information, see Amazon DynamoDB built-in module.
The PutItem request enables you to create or replace items in DynamoDB through
AWS AppSync. The request specifies the following:
-
Item Key: The unique identifier for the DynamoDB item
-
Item Contents: The complete item data, including both the
keyandattributeValues -
Operation Conditions (optional): Rules that must be met for the operation to proceed
The PutItem request has the following structure:
type DynamoDBPutItemRequest = { operation: 'PutItem'; key: { [key: string]: any }; attributeValues: { [key: string]: any}; condition?: ConditionCheckExpression; customPartitionKey?: string; populateIndexFields?: boolean; _version?: number; };
The TypeScript definition above shows all available fields for the request. While you can construct this request manually, we recommend using the DynamoDB built-in module for generating accurate and efficient requests.
PutItem fields
-
operation -
The DynamoDB operation to perform. To perform the
PutItemDynamoDB operation, this must be set toPutItem. This value is required. -
key -
The key of the item in DynamoDB. DynamoDB items may have a single hash key, or a hash key and sort key, depending on the table structure. For more information about how to specify a “typed value”, see Type system (request mapping). This value is required.
-
attributeValues -
The rest of the attributes of the item to be put into DynamoDB. For more information about how to specify a “typed value”, see Type system (request mapping). This field is optional.
-
condition -
A condition to determine if the request should succeed or not, based on the state of the object already in DynamoDB. If no condition is specified, the
PutItemrequest overwrites any existing entry for that item. For more information about conditions, see Condition expressions. This value is optional. -
_version -
A numeric value that represents the latest known version of an item. This value is optional. This field is used for Conflict Detection and is only supported on versioned data sources.
customPartitionKey-
When enabled, this string value modifies the format of the
ds_skandds_pkrecords used by the delta sync table when versioning has been enabled (for more information, see Conflict detection and sync in the AWS AppSync Developer Guide). When enabled, the processing of thepopulateIndexFieldsentry is also enabled. This field is optional.Not supported in AWS AppSync Events
populateIndexFields-
A boolean value that, when enabled along with the
customPartitionKey, creates new entries for each record in the delta sync table, specifically in thegsi_ds_pkandgsi_ds_skcolumns. For more information, see Conflict detection and sync in the AWS AppSync Developer Guide. This field is optional.The item written to DynamoDB is automatically converted to JSON primitive types and is available in the context result (
context.result).
For more information about DynamoDB type conversion, see Type system (response mapping).
For more information about the DynamoDB PutItem API, see the DynamoDB
API documentation.