Class EnumJavaType<T extends Enum<T>>

java.lang.Object
org.hibernate.type.descriptor.java.AbstractClassJavaType<T>
org.hibernate.type.descriptor.java.EnumJavaType<T>
All Implemented Interfaces:
Serializable, BasicJavaType<T>, JavaType<T>

public class EnumJavaType<T extends Enum<T>> extends AbstractClassJavaType<T>
Describes a Java enum type.
See Also:
  • Constructor Details

    • EnumJavaType

      public EnumJavaType(Class<T> type)
  • Method Details

    • getRecommendedJdbcType

      public JdbcType getRecommendedJdbcType(JdbcTypeIndicators context)
      Description copied from interface: BasicJavaType
      Obtain the "recommended" SQL type descriptor for this Java type. Often, but not always, the source of this recommendation is the JDBC specification.
      Parameters:
      context - Contextual information
      Returns:
      The recommended SQL type descriptor
    • hasManyValues

      public boolean hasManyValues()
    • useObjectEqualsHashCode

      public boolean useObjectEqualsHashCode()
      Description copied from interface: JavaType
      Whether to use Object.equals(Object) and Object.hashCode() or JavaType.areEqual(Object, Object) and JavaType.extractHashCode(Object) for objects of this java type. This is useful to avoid mega-morphic callsites.
    • toString

      public String toString(T value)
    • fromString

      public T fromString(CharSequence string)
    • unwrap

      public <X> X unwrap(T value, Class<X> type, WrapperOptions options)
      Description copied from interface: JavaType
      Unwrap an instance of our handled Java type into the requested type.

      As an example, if this is a JavaType<Integer> and we are asked to unwrap the Integer value as a Long, we would return something like Long.valueOf( value.longValue() ).

      Intended use is during PreparedStatement binding.

      Type Parameters:
      X - The conversion type.
      Parameters:
      value - The value to unwrap
      type - The type as which to unwrap
      options - The options
      Returns:
      The unwrapped value.
    • wrap

      public <X> T wrap(X value, WrapperOptions options)
      Description copied from interface: JavaType
      Wrap a value as our handled Java type.

      Intended use is during ResultSet extraction.

      Type Parameters:
      X - The conversion type.
      Parameters:
      value - The value to wrap.
      options - The options
      Returns:
      The wrapped value.
    • toByte

      public Byte toByte(T domainForm)
      Convert a value of the enum type to its ordinal value
    • toShort

      public Short toShort(T domainForm)
      Convert a value of the enum type to its ordinal value
    • toInteger

      public Integer toInteger(T domainForm)
      Convert a value of the enum type to its ordinal value
    • toLong

      public Long toLong(T domainForm)
      Convert a value of the enum type to its ordinal value
    • toOrdinal

      public Integer toOrdinal(T domainForm)
      Convert a value of the enum type to its ordinal value
    • fromByte

      public T fromByte(Byte relationalForm)
      Interpret a numeric value as the ordinal of the enum type
    • fromShort

      public T fromShort(Short relationalForm)
      Interpret a numeric value as the ordinal of the enum type
    • fromInteger

      public T fromInteger(Integer relationalForm)
      Interpret a numeric value as the ordinal of the enum type
    • fromLong

      public T fromLong(Long relationalForm)
      Interpret a numeric value as the ordinal of the enum type
    • fromOrdinal

      public T fromOrdinal(Integer relationalForm)
      Interpret a numeric value as the ordinal of the enum type
    • toName

      public String toName(T domainForm)
      Convert a value of the enum type to its name value
    • fromName

      public T fromName(String relationalForm)
      Interpret a string value as the named value of the enum type
    • getCheckCondition

      public String getCheckCondition(String columnName, JdbcType jdbcType, BasicValueConverter<?,?> converter, Dialect dialect)
      Description copied from interface: JavaType
      The check constraint that should be added to the column definition in generated DDL.
      Parameters:
      columnName - the name of the column
      jdbcType - the JdbcType of the mapped column
      converter - the converter, if any, or null
      dialect - the SQL Dialect
      Returns:
      a check constraint condition or null