É possível ter um campo de enumeração em uma classe persistida com Ormlite?

StackOverflow https://stackoverflow.com/questions/3044632

  •  27-09-2019
  •  | 
  •  

Pergunta

Estou tentando persistir a aula seguinte com Ormlite:

public class Field {
    @DatabaseField(id = true)
    public String name;

    @DatabaseField(canBeNull = false)
    public FieldType type;
    ...
}

o FieldType é um public enum. O campo, correspondente ao type é string no sqlite (IS não suporta enums). Quando tento usá -lo, recebo a seguinte exceção:

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

Então, como digo a Ormlite, os valores do lado java são de um enum?

Foi útil?

Solução

Ormlite pode persistir enums como o VARCHAR Nome da enumeração (padrão):

// this saves it as a string in the database
@DatabaseField
OurEnum ourEnum;
...
private enum OurEnum {
    FIRST,
    SECOND, ;
}

Como alternativa, você pode salvar o ordinal INTEGER.

// this saves it as an integer in the database
@DatabaseField(dataType = DataType.ENUM_INTEGER)
OurEnum ourEnum;

Embora você posso armazenar o ordinal, o VARCHAR A versão de nome (que é o padrão) é recomendada, pois o valor ordinal pode alterar se você adicionar ou remover entradas da enumeração.

Para ambos os tipos de enum, você pode especificar um unknownEnumName = "..." campo o que ajuda na compatibilidade para frente e para trás. Se o banco de dados contiver um valor desconhecido para a enumeração, o objeto retornado pelo DAOS terá esse valor de enumeração.

@DatabaseField(unknownEnumName = "FIRST")
OurEnum ourEnum;
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top