0

我有三个实体,其中Email&实体是从实体Sms继承的Message

public class Message 
{
    virtual public long Id { get; set; }
    virtual public string Body { get; set; }
}

public class Email : Message 
{
    virtual public string Subject { get; set; }
    virtual public string ToAddress { get; set; }
}

public class Sms : Message 
{
    virtual public string Number{ get; set; }
}

映射:

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Core.Domain" namespace="Core.Domain.Model">
  <class name="Message" table="Core_Message"  >

    <id name="Id" >
      <generator class="native" />
    </id>

    <version name="Version"/>

    <property name="Body" not-null="true"/>   

  </class>
</hibernate-mapping>

,

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Core.Domain" namespace="Core.Domain.Model">
  <union-subclass name="Email" extends="Message" table="Core_Email"  >

    <property name="Subject"/>

    <property name="ToAddress"/>

  </union-subclass>
</hibernate-mapping>

,

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Core.Domain" namespace="Core.Domain.Model">
      <union-subclass name="Sms" extends="Message" table="Core_Sms"  >

        <property name="Number"/>   

      </union-subclass>
    </hibernate-mapping>

这条消息我有一个例外: Cannot use identity column key generation with <union-subclass> mapping for: Core.Domain.Model.Message

我需要什么策略来生成Id而不是native?我希望 Id 的值是:1,2,3,4,5,6,... 1,3,5 用于电子邮件,2,4,6 用于 Sms

4

1 回答 1

2

该标识符在继承层次结构中涉及的所有表中必须是唯一的。因此,不允许为每个表单独工作的生成器。在 NHibernate 参考中关于生成器的部分中查看(一些)可用算法的列表。hilo 算法对于数字身份很常见,但不一定是最容易手动使用的。

于 2013-08-06T20:28:09.930 回答