EntityStoreException: 不支持 属性 类型 id 9
EntityStoreException: Unsupported property type id 9
使用 Xodus 版本 1.3.124
并且数据库正在抛出:
jetbrains.exodus.entitystore.EntityStoreException: Unsupported property type id 9
at jetbrains.exodus.entitystore.tables.PropertyTypes.getPropertyType(PropertyTypes.java:56)
at jetbrains.exodus.entitystore.tables.PropertyTypes.entryToPropertyValue(PropertyTypes.java:86)
at jetbrains.exodus.entitystore.PersistentEntityStoreImpl.getPropertyValue(PersistentEntityStoreImpl.java:843)
at jetbrains.exodus.entitystore.PersistentEntityStoreImpl.getProperty(PersistentEntityStoreImpl.java:827)
at jetbrains.exodus.entitystore.PersistentEntity.getProperty(PersistentEntity.java:114)
尽管 属性 正在注册:
@Override
public PersistentEntityStore getPersistentEntityStore(String xodusRoot, String dir, boolean isReadOnly) {
if(persistentEntityStoreCache == null) {
persistentEntityStoreCache = buildPersistentEntityStoreCache();
}
PersistentEntityStore entityStore = persistentEntityStoreCache.get(xodusRoot + dir);
if (entityStore == null) {
Environment environment = getEnvironment(xodusRoot, dir);
PersistentEntityStoreConfig config = new PersistentEntityStoreConfig();
config.setManagementEnabled(false);
config.setDebugSearchForIncomingLinksOnDelete(true);
config.setRefactoringHeavyLinks(true);
entityStore = PersistentEntityStores.newInstance(config, environment, "persistentEntityStore");
PersistentEntityStore finalEntityStore = entityStore;
entityStore.executeInTransaction(
txn -> {
finalEntityStore.registerCustomPropertyType(
txn, EmbeddedEntityIterable.class, EmbeddedEntityBinding.BINDING);
finalEntityStore.registerCustomPropertyType(
txn, EmbeddedArrayIterable.class, EmbeddedEntityBinding.BINDING);
persistentEntityStoreCache.put(xodusRoot + dir, finalEntityStore);
});
}
PersistentEntityStore persistentEntityStore = persistentEntityStoreCache.get(xodusRoot + dir);
return persistentEntityStore;
}
而此 属性 最初保存于:
metaDataHashMap.put("uniqueProperties", uProperties);
finalEntity.setProperty(metadataProperty, new EmbeddedEntityIterable(metaDataHashMap));
这里可能有什么问题?
我找到了问题的根本原因。
最初,EmbeddedEntityIterable
在 com.mybusiness.model.EmbeddedEntityIterable
下面,后来移到了 com.my-new-business.model.EmbeddedEntityIterable
这解决了问题。然而,Xodus 应该有一个工具来替换或至少在这种情况下替换引用模型被移动。
使用 Xodus 版本 1.3.124
并且数据库正在抛出:
jetbrains.exodus.entitystore.EntityStoreException: Unsupported property type id 9
at jetbrains.exodus.entitystore.tables.PropertyTypes.getPropertyType(PropertyTypes.java:56)
at jetbrains.exodus.entitystore.tables.PropertyTypes.entryToPropertyValue(PropertyTypes.java:86)
at jetbrains.exodus.entitystore.PersistentEntityStoreImpl.getPropertyValue(PersistentEntityStoreImpl.java:843)
at jetbrains.exodus.entitystore.PersistentEntityStoreImpl.getProperty(PersistentEntityStoreImpl.java:827)
at jetbrains.exodus.entitystore.PersistentEntity.getProperty(PersistentEntity.java:114)
尽管 属性 正在注册:
@Override
public PersistentEntityStore getPersistentEntityStore(String xodusRoot, String dir, boolean isReadOnly) {
if(persistentEntityStoreCache == null) {
persistentEntityStoreCache = buildPersistentEntityStoreCache();
}
PersistentEntityStore entityStore = persistentEntityStoreCache.get(xodusRoot + dir);
if (entityStore == null) {
Environment environment = getEnvironment(xodusRoot, dir);
PersistentEntityStoreConfig config = new PersistentEntityStoreConfig();
config.setManagementEnabled(false);
config.setDebugSearchForIncomingLinksOnDelete(true);
config.setRefactoringHeavyLinks(true);
entityStore = PersistentEntityStores.newInstance(config, environment, "persistentEntityStore");
PersistentEntityStore finalEntityStore = entityStore;
entityStore.executeInTransaction(
txn -> {
finalEntityStore.registerCustomPropertyType(
txn, EmbeddedEntityIterable.class, EmbeddedEntityBinding.BINDING);
finalEntityStore.registerCustomPropertyType(
txn, EmbeddedArrayIterable.class, EmbeddedEntityBinding.BINDING);
persistentEntityStoreCache.put(xodusRoot + dir, finalEntityStore);
});
}
PersistentEntityStore persistentEntityStore = persistentEntityStoreCache.get(xodusRoot + dir);
return persistentEntityStore;
}
而此 属性 最初保存于:
metaDataHashMap.put("uniqueProperties", uProperties);
finalEntity.setProperty(metadataProperty, new EmbeddedEntityIterable(metaDataHashMap));
这里可能有什么问题?
我找到了问题的根本原因。
最初,EmbeddedEntityIterable
在 com.mybusiness.model.EmbeddedEntityIterable
下面,后来移到了 com.my-new-business.model.EmbeddedEntityIterable
这解决了问题。然而,Xodus 应该有一个工具来替换或至少在这种情况下替换引用模型被移动。