我有以下类,它在戏剧中使用 morphia 持久化到 mongodb 中!应用。该类驻留在一个模块中,该模块是另一个游戏的依赖项!应用。
它的配置是从文件中读取的,并在初始加载时持久保存到数据库中(如果它还没有在数据库中),然后后续请求使用数据库版本。
@Entity
public class Page extends Model {
@Id
public Long navigationId;
// etc ...
}
初始加载和后续查询访问正常,我可以在 mongo 中看到该页面:
> db.Page.find({_id:20000})
{ "_id" : NumberLong(20000), "className" : "models.Page" etc }
但是,如果我重新开始玩!或进行代码更改导致 Morphia 被重新初始化(MorphiaPlugin-1.2.4> initialized
出现在日志中)我得到以下堆栈跟踪:
Caused by: java.lang.RuntimeException: java.lang.RuntimeException: com.google.code.morphia.mapping.MappingException: Error setting value from converter (LongConverter) for models.Page.navigationId to 20000
at com.google.code.morphia.mapping.Mapper.fromDb(Mapper.java:487)
at com.google.code.morphia.mapping.Mapper.fromDBObject(Mapper.java:267)
at com.google.code.morphia.query.MorphiaIterator.convertItem(MorphiaIterator.java:66)
at com.google.code.morphia.query.MorphiaIterator.processItem(MorphiaIterator.java:53)
at com.google.code.morphia.query.MorphiaIterator.next(MorphiaIterator.java:48)
at com.google.code.morphia.query.QueryImpl.asList(QueryImpl.java:255)
at play.modules.morphia.Model$MorphiaQuery.asList(Model.java:1067)
at models.Page.findAll(Page.java)
at plugins.PageConfigLoadPlugin.loadPersistedPages(PageConfigLoadPlugin.java:62)
at plugins.PageConfigLoadPlugin.onApplicationStart(PageConfigLoadPlugin.java:51)
at play.plugins.PluginCollection.onApplicationStart(PluginCollection.java:425)
at play.Play.start(Play.java:495)
... 3 more
Caused by: java.lang.RuntimeException: com.google.code.morphia.mapping.MappingException: Error setting value from converter (LongConverter) for models.Page.navigationId to 20000
at com.google.code.morphia.mapping.ValueMapper.fromDBObject(ValueMapper.java:27)
at com.google.code.morphia.mapping.Mapper.readMappedField(Mapper.java:501)
at com.google.code.morphia.mapping.Mapper.fromDb(Mapper.java:484)
... 14 more
Caused by: com.google.code.morphia.mapping.MappingException: Error setting value from converter (LongConverter) for models.Page.navigationId to 20000
at com.google.code.morphia.converters.DefaultConverters.fromDBObject(DefaultConverters.java:133)
at com.google.code.morphia.mapping.ValueMapper.fromDBObject(ValueMapper.java:25)
... 16 more
如果我使用命令行从 mongodb 中删除 Collection,我可以再次从我的游戏中成功加载和查询 Page obejct!Web应用程序
> db.Page.drop()
true
正如我所提到的,这个类在一个模块中。此问题仅发生在该模块所依赖的一个应用程序中。另一个演示应用程序工作正常。
有什么建议么?