在流畅的NHibernate子类映射中映射多列用户类型的正确方法是什么



对于我正在进行的项目,我使用自定义类型将数据库中的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

最新更新