- All Known Implementing Classes:
HistoryResolution,HistoryStatus
public interface EnumType
A SQL enum type. This can be any of the following:
- In
SQLDialect.MARIADB, this can be a column-scope enum type - In
SQLDialect.MYSQL, this can be a column-scope enum type - In
SQLDialect.POSTGRES, this can be a schema-scope enum type - In all other dialects, this can be an enum type as defined in the code generation configuration [#968]
Client code should not assume that the actual enum reference is a Java
Enum. In Scala, for instance, enums are not idiomatic, and jOOQ
implements them differently. In any case, this EnumType API is
implemented by generated database enums.
- Author:
- Lukas Eder
-
Method Summary
Modifier and TypeMethodDescriptiondefault @Nullable CatalogThe catalog of the enum type, if applicable.@NotNull StringThe literal as defined in the database@Nullable StringgetName()The type name as registered in the database, if applicable (Postgres schema-scope enum type only).default @Nullable SchemaThe schema of the enum type, if applicable (Postgres schema-scope enum type only).lookupLiteral(Class<E> enumType, String literal) Look up anEnumTypevalue by itsgetLiteral().
-
Method Details
-
getLiteral
The literal as defined in the database -
getCatalog
The catalog of the enum type, if applicable. Otherwise, this returnsnull -
getSchema
The schema of the enum type, if applicable (Postgres schema-scope enum type only). Otherwise, this returnsnull -
getName
The type name as registered in the database, if applicable (Postgres schema-scope enum type only). Otherwise, this returnsnull -
lookupLiteral
Look up anEnumTypevalue by itsgetLiteral().This is similar to
Enum.valueOf(Class, String), but usesgetLiteral()(the database enum value) as a lookup key instead ofEnum.name()(the generated Java value), and returnsnullif the literal wasn't found.
-