2

我在这里遇到类映射问题。我有四张桌子:

  • 使固定
  • 要求
  • 控制
  • 信息

Request具有表的外键FixMessage,而Control具有 的外键Request。基本映射工作正常,但我不想直接在类型Request之间映射外键,因为我们不会使用此类 - 我们通过访问此消息表的各种视图进行所有插入和选择。要使用的视图将取决于存储在表中的值,例如,是一个视图(我们不使用所有字段,还有其他业务特定原因我们不想使用表)。MessageMessageFixMessage101MessageMessage

对于指定的场景,基本思想是有这样的映射:

public class Request: Entity
{
    public virtual short Number { get; set; }      
    public virtual Fix Fix { get; set; }
    public virtual IMessage Message { get; set; }
}

IMessage由所有Message类实现的接口。我尝试在Request课堂上使用泛型,但无济于事。也许使用MappingOverride可以帮助?

谢谢

编辑:

为了使用Any,我将用于查找对象类型的值放在Request表上,所以我的覆盖看起来像:

    public override void OverrideMapping(IClassMapper<Request> __m)
    {
        __m.Any(x => x.Envio, typeof(long), m =>
            {
                m.IdType<long>();
                m.MetaType<short>();
                m.MetaValue(101, typeof(Message101));

                m.Columns(id =>
                {
                    id.Name("MessageId");
                    id.NotNullable(true);
                }, classRef =>
                {
                    classRef.Name("MessageType");
                    classRef.NotNullable(true);
                });

                m.Access(Accessor.Property);
                m.Cascade(Cascade.None);                   

            }
        );
    }           

但我一直收到not-null property references a null or transient value错误。有任何想法吗?

4

1 回答 1

0

毕竟,我必须将鉴别器字段的引用放在 上Request,这使我能够使用Any来自 NHibernate 的映射。我在编辑问题时描述的问题在我看来与问题本身无关,因此,Daniel Schilling提出的解决方案解决了我的问题。关于Any映射,可以在此处找到其工作原理的描述。

于 2013-10-18T14:09:37.657 回答