2

我正在尝试像这样急切地加载一些子实体:

_context.Sites.Where(x => x.ID == siteID).Include(s => s.SiteLoggers).FirstOrDefault();

但是,我得到的错误是:

A specified Include path is not valid. The EntityType 'MyProject.Dal.EF.Site' does not declare a navigation property with the name 'SiteLoggers'.

说的是正确的,因为 MyProject.Dal.EF.Site 不存在,该对象存在于 MyProject.Domain.Entities.Site

我错过了什么???谢谢!

POCO:

namespace MyProject.Domain.Entities
{
    public class Site
    {
        public int ID { get; set; }
        public int LocationID { get; set; }
        public bool Active { get; set; }
        public bool Deleted { get; set; }
        public string Name { get; set; }
        public virtual Location Location { get; set; }
        public virtual IEnumerable<SiteLogger> SiteLoggers { get; set; }
    }
}

namespace MyProject.Domain.Entities
{
    public class SiteLogger
    {
        public int ID { get; set; }
        public int UID { get; set; }
        public int SiteID { get; set; }
        public string Name { get; set; }
        public int LocationID { get; set; }
        public bool Active { get; set; }
        public bool Deleted { get; set; }
        public virtual Site Site { get; set; }
        public virtual Location Location { get; set; }
    }
}
4

1 回答 1

3

您需要使用ICollection而不是IEnumerable,因为 EF 要求您的导航属性定义为ICollection<T>.

 public virtual ICollection <SiteLogger> SiteLoggers { get; set; }
于 2012-04-24T04:42:17.983 回答