Class LocalDateAttributeConverter
java.lang.Object
software.amazon.awssdk.enhanced.dynamodb.internal.converter.attribute.LocalDateAttributeConverter
- All Implemented Interfaces:
AttributeConverter<LocalDate>
@ThreadSafe
@Immutable
public final class LocalDateAttributeConverter
extends Object
implements AttributeConverter<LocalDate>
A converter between
LocalDate and AttributeValue.
This stores and reads values in DynamoDB as a String.
LocalDates are stored in the official LocalDate format "[-]YYYY-MM-DD", where:
- Y is a year between
Year.MIN_VALUEandYear.MAX_VALUE(prefixed with - if it is negative) - M is a 2-character, zero-prefixed month between 01 and 12
- D is a 2-character, zero-prefixed day between 01 and 31
LocalDate for more details on the serialization format.
This is unidirectional format-compatible with the LocalDateTimeAttributeConverter, allowing values
stored as LocalDate to be retrieved as LocalDateTimes.
This serialization is lexicographically orderable when the year is not negative.
Examples:
LocalDate.of(1988, 5, 21)is stored as as an AttributeValue with the String "1988-05-21"LocalDate.of(0, 1, 1)is stored as as an AttributeValue with the String "0000-01-01"
This can be created via create().
-
Method Summary
Modifier and TypeMethodDescriptionTheAttributeValueTypethat a converter stores and reads values from DynamoDB via theAttributeValueclass.static LocalDateAttributeConvertercreate()transformFrom(LocalDate input) Convert the provided Java object into anAttributeValue.transformTo(AttributeValue input) Convert the providedAttributeValueinto a Java object.type()The type supported by this converter.
-
Method Details
-
create
-
type
Description copied from interface:AttributeConverterThe type supported by this converter.- Specified by:
typein interfaceAttributeConverter<LocalDate>
-
attributeValueType
Description copied from interface:AttributeConverterTheAttributeValueTypethat a converter stores and reads values from DynamoDB via theAttributeValueclass.- Specified by:
attributeValueTypein interfaceAttributeConverter<LocalDate>
-
transformFrom
Description copied from interface:AttributeConverterConvert the provided Java object into anAttributeValue. This will raise aRuntimeExceptionif the conversion fails, or the input is null.Example:
InstantAsStringAttributeConverter converter = InstantAsStringAttributeConverter.create(); assertEquals(converter.transformFrom(Instant.EPOCH), EnhancedAttributeValue.fromString("1970-01-01T00:00:00Z").toAttributeValue());- Specified by:
transformFromin interfaceAttributeConverter<LocalDate>
-
transformTo
Description copied from interface:AttributeConverterConvert the providedAttributeValueinto a Java object. This will raise aRuntimeExceptionif the conversion fails, or the input is null.Example:
InstantAsStringAttributeConverter converter = InstantAsStringAttributeConverter.create(); assertEquals(converter.transformTo(EnhancedAttributeValue.fromString("1970-01-01T00:00:00Z").toAttributeValue()), Instant.EPOCH);- Specified by:
transformToin interfaceAttributeConverter<LocalDate>
-