¿Es posible tener un campo de enumeración en una clase persistido con OrmLite?
Pregunta
Estoy tratando de persistir la siguiente clase con OrmLite :
public class Field {
@DatabaseField(id = true)
public String name;
@DatabaseField(canBeNull = false)
public FieldType type;
...
}
El FieldType
es un public enum
. El campo, que corresponde a la type
es cadena en SQLite (es no soporta las enumeraciones). Cuando trato de usarlo, me sale el siguiente excepción:
INFO [main] (SingleConnectionDataSource.java:244) - Established shared JDBC Connection: org.sqlite.Conn@5224ee
Exception in thread "main" org.springframework.beans.factory.BeanInitializationException: Initialization of DAO failed; nested exception is java.lang.IllegalArgumentException: Unknown field class class enums.FieldType for field FieldType:name=type,class=class orm.Field
at org.springframework.dao.support.DaoSupport.afterPropertiesSet(DaoSupport.java:51)
at orm.FieldDAO.getInstance(FieldDAO.java:17)
at orm.Field.fromString(Field.java:23)
at orm.Field.main(Field.java:38)
Caused by: java.lang.IllegalArgumentException: Unknown field class class enums.FieldType for field FieldType:name=type,class=class orm.Field
at com.j256.ormlite.field.FieldType.<init>(FieldType.java:54)
at com.j256.ormlite.field.FieldType.createFieldType(FieldType.java:381)
at com.j256.ormlite.table.DatabaseTableConfig.fromClass(DatabaseTableConfig.java:82)
at com.j256.ormlite.dao.BaseJdbcDao.initDao(BaseJdbcDao.java:116)
at org.springframework.dao.support.DaoSupport.afterPropertiesSet(DaoSupport.java:48)
... 3 more
Entonces, ¿cómo le digo a OrmLite, valores en el lado de Java son de un enum
?
Solución
ORMLite puede persistir enumeraciones ya sea como la VARCHAR
enum nombre (por defecto) :
// this saves it as a string in the database
@DatabaseField
OurEnum ourEnum;
...
private enum OurEnum {
FIRST,
SECOND, ;
}
Como alternativa, puede guardar el ordinal INTEGER
.
// this saves it as an integer in the database
@DatabaseField(dataType = DataType.ENUM_INTEGER)
OurEnum ourEnum;
A pesar de que puede almacenar el ordinal, se recomienda la versión de VARCHAR
(que es el valor por defecto), ya que el valor ordinal puede cambiar si se agrega o entradas de eliminar de la enumeración.
Para ambos tipos de enumeración, se puede especificar un unknownEnumName = "..."
campo que ayuda con la compatibilidad hacia adelante y atrás . Si la base de datos contiene un valor desconocido para la enumeración entonces el objeto que se devuelve por los DAOs tendrá este valor de enumeración.
@DatabaseField(unknownEnumName = "FIRST")
OurEnum ourEnum;