クラスの列挙フィールドをOrmliteで持続することは可能ですか?
質問
次のクラスを維持しようとしています ormlite:
public class Field {
@DatabaseField(id = true)
public String name;
@DatabaseField(canBeNull = false)
public FieldType type;
...
}
FieldType
aです public enum
. 。に対応するフィールド type
sqliteの文字列です(enumsをサポートしていません)。私がそれを使用しようとするとき、私は次の例外を取得します:
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
では、ormliteを伝えるにはどうすればよいですか、Java側の価値は enum
?
解決
ormlite どちらかのように列挙を持続できます VARCHAR
列挙名(デフォルト):
// this saves it as a string in the database
@DatabaseField
OurEnum ourEnum;
...
private enum OurEnum {
FIRST,
SECOND, ;
}
別の方法として、保存できます 順序 INTEGER
.
// this saves it as an integer in the database
@DatabaseField(dataType = DataType.ENUM_INTEGER)
OurEnum ourEnum;
あなたは できる 順序を保存します VARCHAR
名前バージョン(デフォルト)が推奨されます。これは、enumからエントリを追加または削除すると順序の値が変更される可能性があるためです。
両方の列挙型について、Anを指定できます unknownEnumName = "..."
分野 これは、前方および後方の互換性に役立ちます。データベースに列挙の不明な値が含まれている場合、DAOSによって返されるオブジェクトにはこの列挙値があります。
@DatabaseField(unknownEnumName = "FIRST")
OurEnum ourEnum;
所属していません StackOverflow