import { _AttributeValue, _UnmarshalledAttributeValue } from './_AttributeValue'; /** *

For the UpdateItem operation, represents the attributes to be modified, the action to perform on each, and the new value for each.

You cannot use UpdateItem to update any primary key attributes. Instead, you will need to delete the item, and then use PutItem to create a new item with new attributes.

Attribute values cannot be null; string and binary type attributes must have lengths greater than zero; and set type attributes must not be empty. Requests with empty values will be rejected with a ValidationException exception.

*/ export interface _AttributeValueUpdate { /** *

Represents the data for an attribute.

Each attribute value is described as a name-value pair. The name is the data type, and the value is the data itself.

For more information, see Data Types in the Amazon DynamoDB Developer Guide.

*/ Value?: _AttributeValue; /** *

Specifies how to perform the update. Valid values are PUT (default), DELETE, and ADD. The behavior depends on whether the specified primary key already exists in the table.

If an item with the specified Key is found in the table:

If no item with the specified Key is found:

*/ Action?: 'ADD' | 'PUT' | 'DELETE' | string; } export interface _UnmarshalledAttributeValueUpdate extends _AttributeValueUpdate { /** *

Represents the data for an attribute.

Each attribute value is described as a name-value pair. The name is the data type, and the value is the data itself.

For more information, see Data Types in the Amazon DynamoDB Developer Guide.

*/ Value?: _UnmarshalledAttributeValue; }