org.hibernate.mapping.PropertyGeneration 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.mapping;
import java.io.Serializable;
/**
* Indicates whether given properties are generated by the database and, if
* so, at what time(s) they are generated.
*
* @author Steve Ebersole
*
* @deprecated This is replaced by {@link org.hibernate.tuple.ValueGeneration} and {@link org.hibernate.tuple.GenerationTiming}
*/
@Deprecated
public class PropertyGeneration implements Serializable {
/**
* Values for this property are never generated by the database.
*/
public static final PropertyGeneration NEVER = new PropertyGeneration( "never" );
/**
* Values for this property are generated by the database on insert.
*/
public static final PropertyGeneration INSERT = new PropertyGeneration( "insert" );
/**
* Values for this property are generated by the database on both insert and update.
*/
public static final PropertyGeneration ALWAYS = new PropertyGeneration( "always" );
private final String name;
private PropertyGeneration(String name) {
this.name = name;
}
public String getName() {
return name;
}
public static PropertyGeneration parse(String name) {
if ( "insert".equalsIgnoreCase( name ) ) {
return INSERT;
}
else if ( "always".equalsIgnoreCase( name ) ) {
return ALWAYS;
}
else {
return NEVER;
}
}
private Object readResolve() {
return parse( name );
}
public String toString() {
return getClass().getName() + "(" + getName() + ")";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy