All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.dynamodbv2.datamodeling.DynamoDBScalarAttribute Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon DynamoDB module holds the client classes that are used for communicating with Amazon DynamoDB Service

There is a newer version: 1.9.11
Show newest version
/*
 * Copyright 2016-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 *    http://aws.amazon.com/apache2.0
 *
 * This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES
 * OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and
 * limitations under the License.
 */
package com.amazonaws.services.dynamodbv2.datamodeling;

import com.amazonaws.services.dynamodbv2.model.ScalarAttributeType;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * Annotation to override the standard scalar type conversion.
 *
 * 

A minimal example using getter annotations,

*
 * @DynamoDBTable(tableName="TestTable")
 * public class TestClass {
 *     private UUID key;
 *     private Locale locale;
 *
 *     @DynamoDBHashKey
 *     @DynamoDBScalarAttribute(type=ScalarAttributeType.B)
 *     public UUID getKey() { return this.key; }
 *     public void setKey(UUID key) { this.key = key; }
 *
 *     @DynamoDBScalarAttribute(type=ScalarAttributeType.S)
 *     public Locale getLocale() { return this.locale; }
 *     public void setLocale(Locale locale) { this.locale = locale; }
 * }
 * 
* *

Here we are overriding the standard {@link java.util.UUID} type conversion * to {@link java.nio.ByteBuffer} rather than the default {@link String}.

* *

Please note, the conversion function needs to be present in the * type-converter factory.

* *

To add or override scalar type-conversions,

*
 * final DynamoDBMapperConfig.Builder builder = new DynamoDBMapperConfig.Builder();

 * final DynamoDBTypeConverterFactory.OverrideFactory factory = builder.newTypeConverterFactory();
 * factory.with(String.class, Locale.class, new DynamoDBTypeConverter<String,Locale>() {
 *     public String convert(Locale object) {
 *         return object.toLanguageTag();
 *     }
 *     public Locale unconvert(final String object) {
 *         return Locale.forLanguageTag(object);
 *     }
 * });
 *
 * final DynamoDBMapperConfig config = builder.build();
 * 
* * @see com.amazonaws.services.dynamodbv2.datamodeling.DynamoDBTypeConverted * @see com.amazonaws.services.dynamodbv2.model.ScalarAttributeType */ @DynamoDB @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.FIELD, ElementType.METHOD}) public @interface DynamoDBScalarAttribute { /** * The scalar attirbute type. * @see com.amazonaws.services.dynamodbv2.model.ScalarAttributeType */ ScalarAttributeType type(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy