/* * Copyright 2007 Amazon Technologies, Inc. or its affiliates. * Amazon, Amazon.com and Carbonado are trademarks or registered trademarks * of Amazon Technologies, 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://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License 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.amazon.carbonado; import java.lang.annotation.*; /** * Identifies a {@link Storable} property which is not directly persisted, but * is instead derived from other property values. A derived property cannot be * abstract, and a "set" method is optional. * *
Derived properties can be used just like a normal property in most * cases. They can be used in query filters, indexes, alternate keys, and they * can also be used to define a {@link Version} property. * *
If the derived property depends on {@link Join} properties and is also * used in an index or alternate key, dependencies must be listed in order for * the index to be properly updated. * *
Example:
* @Indexes(@Index("uppercaseName")) * public abstract class UserInfo implements Storable<UserInfo> { * /** * * Derive an uppercase name for case-insensitive searches. * */ * @Derived * public String getUppercaseName() { * String name = getName(); * return name == null ? null : name.toUpperCase(); * } * * ... * } ** * @author Brian S O'Neill * @since 1.2 */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface Derived { /** * List of properties that this property is derived from. */ String[] from() default {}; }