Class ZonedDateTimeAsStringAttributeConverter
- All Implemented Interfaces:
AttributeConverter<ZonedDateTime>
ZonedDateTime and AttributeValue.
This stores values in DynamoDB as a string.
Values are stored in a ISO-8601-like format, with the non-offset zone IDs being added at the end of the string in square
brackets. If the zone ID offset has seconds, then they will also be included, even though this is not part of the ISO-8601
standard. For full ISO-8601 compliance, it is better to use OffsetDateTimes (without second-level precision in its
offset) or Instants, assuming the time zone information is not strictly required.
Examples:
Instant.EPOCH.atZone(ZoneId.of("Europe/Paris"))is stored as an AttributeValue with the String "1970-01-01T01:00+01:00[Europe/Paris]"OffsetDateTime.MIN.toZonedDateTime()is stored as an AttributeValue with the String "-999999999-01-01T00:00+18:00"OffsetDateTime.MAX.toZonedDateTime()is stored as an AttributeValue with the String "+999999999-12-31T23:59:59.999999999-18:00"Instant.EPOCH.atZone(ZoneOffset.UTC)is stored as an AttributeValue with the String "1970-01-01T00:00Z"
OffsetDateTime for more details on the serialization format.
This converter can read any values written by itself, InstantAsStringAttributeConverter,
or OffsetDateTimeAsStringAttributeConverter. Values written by
Instant converters are treated as if they are in the UTC time zone.
This serialization is lexicographically orderable when the year is not negative.
This can be created via create().
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionTheAttributeValueTypethat a converter stores and reads values from DynamoDB via theAttributeValueclass.create()transformFrom(ZonedDateTime input) Convert the provided Java object into anAttributeValue.transformTo(AttributeValue input) Convert the providedAttributeValueinto a Java object.type()The type supported by this converter.
-
Constructor Details
-
ZonedDateTimeAsStringAttributeConverter
public ZonedDateTimeAsStringAttributeConverter()
-
-
Method Details
-
create
-
type
Description copied from interface:AttributeConverterThe type supported by this converter.- Specified by:
typein interfaceAttributeConverter<ZonedDateTime>
-
attributeValueType
Description copied from interface:AttributeConverterTheAttributeValueTypethat a converter stores and reads values from DynamoDB via theAttributeValueclass.- Specified by:
attributeValueTypein interfaceAttributeConverter<ZonedDateTime>
-
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<ZonedDateTime>
-
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<ZonedDateTime>
-