5

我正在尝试创建一个自定义模型(例如博客文章),该模型与 MVC 4 模板中用于注册和 oAuth 身份验证的 WebSecurity 功能使用的实体“UserProfile”相关。

下面的例子:

public class Post
{
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
    public int Id { get; set; }
    public string Detail { get; set; }
    public UserProfile User { get; set; }
}

我能够正确地将当前的 UserProfile 与博客文章相关联,如下所示:

post.User = user = db.UserProfiles.FirstOrDefault(u => u.UserName.ToLower() == WebSecurity.CurrentUserName);
db.Posts.Add(post);
db.SaveChanges();

但是当我尝试从数据库中获取博客文章时,我为用户获取了一个空对象:

var post = db.Posts.Where(x => x.Id == postId).FirstOrDefault();
post.User is null!

我相信这是因为创建 SimpleMembershipProvider 时在数据库中创建的关系:

WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "Id", "UserName", autoCreateTables: true);

我确定必须有一种方法可以忽略这些或在我的博客类的 User 属性中添加一个属性来克服这个问题?

提前致谢。

4

1 回答 1

0

由于您没有使用急切加载(例如通过使用 .include),因此您必须将 User 属性设置为virtual,因此它可以由 EF 延迟加载(默认情况下,延迟加载已为 DataContext 启用 - 所以如果您没有更改此设置,延迟加载应该可以工作)。

public class Post
{
    ...
    public virtual UserProfile User { get; set; } // navigation properties need to be virtual to support lazy loading
    ...
}

如果您不想延迟加载,则需要包含Navigation(并执行预加载)属性,例如:

var postWithUser = db.Posts
                           .Include(p => p.User)
                           .Where(x => x.Id == postId)
                           .FirstOrDefault();

您可能会发现这篇关于延迟/急切加载的文章很有趣(或者只是谷歌搜索 EF 和延迟/急切加载)

于 2012-12-11T21:53:20.567 回答