Class OptionalLongAttributeConverter
- java.lang.Object
-
- software.amazon.awssdk.enhanced.dynamodb.internal.converter.attribute.OptionalLongAttributeConverter
-
- All Implemented Interfaces:
AttributeConverter<OptionalLong>
@ThreadSafe @Immutable public final class OptionalLongAttributeConverter extends Object implements AttributeConverter<OptionalLong>
A converter betweenOptionalLong
andAttributeValue
.This stores values in DynamoDB as a number.
This supports reading numbers between
Long.MIN_VALUE
andLong.MAX_VALUE
from DynamoDB. Null values are converted toOptionalLong.empty()
. For larger numbers, consider using theOptionalAttributeConverter
along with aBigInteger
. For shorter numbers, consider using theOptionalIntAttributeConverter
orOptionalAttributeConverter
along with aShort
type.This does not support reading decimal numbers. For decimal numbers, consider using
OptionalDoubleAttributeConverter
, or theOptionalAttributeConverter
with aFloat
orBigDecimal
. Decimal numbers will cause aNumberFormatException
on conversion.This can be created via
create()
.
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description AttributeValueType
attributeValueType()
TheAttributeValueType
that a converter stores and reads values from DynamoDB via theAttributeValue
class.static OptionalLongAttributeConverter
create()
AttributeValue
transformFrom(OptionalLong input)
Convert the provided Java object into anAttributeValue
.OptionalLong
transformTo(AttributeValue input)
Convert the providedAttributeValue
into a Java object.EnhancedType<OptionalLong>
type()
The type supported by this converter.
-
-
-
Method Detail
-
type
public EnhancedType<OptionalLong> type()
Description copied from interface:AttributeConverter
The type supported by this converter.- Specified by:
type
in interfaceAttributeConverter<OptionalLong>
-
attributeValueType
public AttributeValueType attributeValueType()
Description copied from interface:AttributeConverter
TheAttributeValueType
that a converter stores and reads values from DynamoDB via theAttributeValue
class.- Specified by:
attributeValueType
in interfaceAttributeConverter<OptionalLong>
-
create
public static OptionalLongAttributeConverter create()
-
transformFrom
public AttributeValue transformFrom(OptionalLong input)
Description copied from interface:AttributeConverter
Convert the provided Java object into anAttributeValue
. This will raise aRuntimeException
if 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:
transformFrom
in interfaceAttributeConverter<OptionalLong>
-
transformTo
public OptionalLong transformTo(AttributeValue input)
Description copied from interface:AttributeConverter
Convert the providedAttributeValue
into a Java object. This will raise aRuntimeException
if 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:
transformTo
in interfaceAttributeConverter<OptionalLong>
-
-