对于我正在进行的项目,我使用自定义类型将数据库中的IP地址作为二进制和地址族对进行处理。
如果我试图在子类映射中映射到我的自定义类型,它会在启动时失败,并出现映射异常
NHibernate.MappingException:属性映射的数目错误列:AddressAsset.地址类型:IPAddressBinaryUserType
失败的映射代码如下:
public class AbstractAssetMap : ClassMap<AbstractAsset>
{
public AbstractFirewallAssetMap()
{
Table("asset");
Id(x => x.FirewallAssetSk).Column("asset_sk").GeneratedBy.Native();
DiscriminateSubClassesOnColumn<string>("type");
// ... other property mappings
}
}
public class AddressAssetMap : SubclassMap<AddressAsset>
{
public AddressAssetMap()
{
DiscriminatorValue(AbstractFirewallAsset.FirewallAssetType.Address);
Map(x => x.Address)
.CustomType<IPAddressBinaryUserType>()
.Columns.Add("address_family", "address");
}
}
// ... other SubclassMaps of AbstractAsset subclasses
如果删除其中一列,则不再引发MappingException。然而,这不是一个解决方案,因为我需要来自这两列的数据。
同样,如果我删除子类并使用相同的自定义类型显式映射子类,它似乎可以工作,并且在映射过程中不会失败。例如:
public class AddressAssetMap : ClassMap<AddressAsset>
{
public AddressAssetMap()
{
Table("asset");
Id(x => x.FirewallAssetSk).Column("asset_sk").GeneratedBy.Native();
Map(x => x.Address)
.CustomType<IPAddressBinaryUserType>()
.Columns.Add("address_family", "address");
// ... other property mappings
}
}
在流畅的NHibernate子类映射中映射多列用户类型的正确方法是什么?
您应该尝试升级fluent nhibernate。请查看已知问题https://github.com/jagregory/fluent-nhibernate/issues/210