首先使用EF代码审核表

时间:2012-06-23 09:47:53

标签: entity-framework-4 ef-code-first entity-framework-mapping

我有一个课程说Message如下:

public class Message
{
    public int Id{get;set;}
    public string MessageText{get;set;}
    public int Sender{get;set;}
    public DateTime CreatedOn{get;set;}

    //EDIT:2
    public virtual Message RepliedTo{get;set;}
    public virtual IList<Message> Replies{get;set;}
    public virtual IList<MessageStatusHistory> History{get;set;}
    //so on and so forth
}

现在我想保留Message对象的状态,例如用户将其标记为已读和何时。我创建了一个类MessageStatusHistory,如:

public class MessageStatusHistory
{
    public int Id{get;set;}
    public string Status{get;set;}
    public DateTime StatusDate{get;set;}
    public int UserId{get;set;}
    public int MessageId{get;set;}//EDIT:2
    public Message Message{get;set;}
}

我对如何设置MessageMessageStatusHistory类的映射感到困惑,以便我可以从对象本身获取Message的所有历史记录。

状态历史记录表在某些用户将其标记为已读之前不会有条目。

编辑:2 我为Message配置了映射,如下所示:

ToTable("Messages");
HasOptional(x => x.RepliedTo).WithMany(x => x.Replies)
    .Map(n => n.ToTable("Messages"));

MessageStatusHistory映射是:

HasRequired(x => x.Message).WithMany(n => n.History)
       .HasForeignKey(x => x.MessageId)

现在我运行以下测试:

using (IKernel ker = new StandardKernel())
{    
    ker.Rebind<IDbContext>().To<MessageDbContext>();
    ker.Rebind<IRepository<Message>>().To<EFRepository<Message>>();
    ker.Rebind<IRepository<MessageStatusHistory>>()
                   .To<EFRepository<MessageStatusHistory>>();

    var svc = ker.Get<MessageService>();
    var message = svc.Create("hello world", 1, "user2@example.com");
    var nn = svc.AddReplyToMessage(message, "Message 2", 1, "user2@example.com");
    var nnn = svc.AddReplyToMessage(nn, "Message 3", 2, "user1@example.com");

    var nhs = ker.Get<MessageStatusHistoryService>();

    nhs.Create(message, Status.MarkedRead, 2, "user1@example.com");
    nhs.Create(message, Status.MarkedRead, 1, "user2@example.com");
    nhs.Create(nnn, Status.MarkedRead, 2, "user1@example.com");
    nhs.Create(nn, Status.MarkedRead, 1, "user2@example.com");
    nhs.Create(nn, Status.MarkedRead, 2, "user1@example.com");
}

创建状态历史记录对象的行正在重新插入Message个对象:(我认为这是因为映射中的HasRequired(x=>x.Message)内容。但不确定。请帮助解决此问题。

0 个答案:

没有答案