2010-06-15 79 views
16

我試圖用OrmLite堅持以下類:是否有可能在類中持有OrmLite的枚舉字段?

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

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

FieldTypepublic enum。該字段對應於type是SQLite中的字符串(不支持枚舉)。當我嘗試使用它,我得到以下異常:

INFO [main] (SingleConnectionDataSource.java:244) - Established shared JDBC Connection: [email protected] 
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 

那我怎麼告訴OrmLite,值在Java端是從enum

回答

39

ORMLite能堅持枚舉無論是作爲VARCHAR enum name (default)

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

作爲替代方案,可以節省ordinal INTEGER

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

雖然你可以序,推薦VARCHAR名稱的版本(這是默認的),因爲如果從枚舉添加或刪除條目序號值可以改變。

對於這兩種枚舉類型,您可以指定一個unknownEnumName = "..." field,這有助於向前和向後兼容。如果數據庫包含枚舉的未知值,則由DAO返回的對象將具有此枚舉值。

@DatabaseField(unknownEnumName = "FIRST") 
OurEnum ourEnum; 
+1

謝謝,你做得很好,反正你認爲通過表格或本網站與你聯繫會更好嗎?我想後者可以節省你的時間,當人們谷歌爲他們想要什麼 – htf 2010-06-18 08:15:15

+0

爲什麼建議使用ENUM_INTEGER?當然,枚舉條目的名稱不太可能比條目的順序或數量更改。 – pablisco 2014-02-10 11:07:13

+0

不推薦。你讀過了@pablisco的答案嗎? – Gray 2014-02-10 14:39:49

相關問題