Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# NHibernate:具有泛型枚举属性的映射类_C#_.net_Nhibernate_Enums_Nhibernate Mapping - Fatal编程技术网

C# NHibernate:具有泛型枚举属性的映射类

C# NHibernate:具有泛型枚举属性的映射类,c#,.net,nhibernate,enums,nhibernate-mapping,C#,.net,Nhibernate,Enums,Nhibernate Mapping,我有一个这样定义的类: public class StateMachineMetadata<T> where T: struct { public virtual int ID { get; protected set; } public virtual T State { get; set; } public virtual DateTime DateChanged { get; set; } } 我可以要两种类型吗 StateMachineMetadat

我有一个这样定义的类:

public class StateMachineMetadata<T> where T: struct
{
    public virtual int ID { get; protected set; }
    public virtual T State { get; set; }
    public virtual DateTime DateChanged { get; set; }
}
我可以要两种类型吗

StateMachineMetadata<CarState>, StateMachineMetadata<OrderState>

,原因如下

假设
StateMachineMetadata
表中有两行:

ID | State | DateChanged
1  |   1   |  2012-02-13
2  |   1   |  2012-02-14
如果
State
列同时映射到
CarState
OrderState
,NHibernate将如何确定反序列化到哪个枚举?一种解决方案是在
StateMachineMetadata
表中添加一个鉴别器列,告诉NHibernate它应该将特定行映射到哪个类型。
例如,
类型
鉴别器列:

ID | State | DateChanged | Type
1  |   1   |  2012-02-13    1
2  |   1   |  2012-02-14    2
告诉NHibernate第一行表示
StateMachineMetadata
,而第二行表示
StateMachineMetadata
。这在NHibernate中称为a。它要求两个类都从一个公共基类继承,在您的情况下,该基类自然是
StateMachineMetadata

但是这里有一个问题:NHibernate没有一种方法来映射具有开放泛型类型的类。原因是,

然而,NHibernate确实允许您使用封闭泛型映射类。你不能把它们映射到同一张表。以下是此类配置的外观:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
           assembly="MyAssembly"
           namespace="MyNamespace">
    <class name="StateMachineMetadata`1[MyNamespace.CarState]"
           table="StateMachineMetadata_CarState">
        <!-- property to column mappings -->
    </class>

    <class name="StateMachineMetadata`1[MyNamespace.OrderState]"
           table="StateMachineMetadata_OrderState">
        <!-- property to column mappings -->
    </class>
</hibernate-mapping>


@Jekas它回答了你的问题吗?是的。但我仍在寻找解决方案,IUserType的一些解决方法可能是。。或者它可能会与具体类型一起工作。
ID | State | DateChanged | Type
1  |   1   |  2012-02-13    1
2  |   1   |  2012-02-14    2
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
           assembly="MyAssembly"
           namespace="MyNamespace">
    <class name="StateMachineMetadata`1[MyNamespace.CarState]"
           table="StateMachineMetadata_CarState">
        <!-- property to column mappings -->
    </class>

    <class name="StateMachineMetadata`1[MyNamespace.OrderState]"
           table="StateMachineMetadata_OrderState">
        <!-- property to column mappings -->
    </class>
</hibernate-mapping>