org.hibernate.annotations.Formula Maven / Gradle / Ivy
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.annotations;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
/**
* Defines a formula (derived value) which is a SQL fragment that acts as a @Column alternative in most cases.
* Represents read-only state.
*
* In certain cases @ColumnTransformer might be a better option, especially as it leaves open the option of still
* being writable.
*
*
* // perform calculations
* @Formula( "sub_total + (sub_total * tax)" )
* long getTotalCost() { ... }
*
*
*
* // call database functions ( e.g. MySQL upper() and substring() )
* @Formula( "upper( substring( middle_name, 1 ) )" )
* Character getMiddleInitial() { ... }
*
*
*
* // this might be better handled through @ColumnTransformer
* @Formula( "decrypt(credit_card_num)" )
* String getCreditCardNumber() { ... }
*
*
* @see ColumnTransformer
*
* @author Emmanuel Bernard
* @author Steve Ebersole
*/
@Target({METHOD, FIELD})
@Retention(RUNTIME)
public @interface Formula {
/**
* The formula string.
*/
String value();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy