【问题标题】:Fluent nHibernate - not Lazy LoadingFluent nHibernate - 不延迟加载
【发布时间】:2013-12-10 21:32:17
【问题描述】:

这可能有点傻,但我可以理解它。我有三张桌子

Post
id
content
...
User 
id
name
...
Vote
user_id
post_id
votedate

我的投票地图:

public class VoteMap : ClassMap<Vote>
{
    public VoteMap()
    {
        DynamicUpdate();

        Table("vote");            
        Id(Reveal.Member<Vote>("_id")).Column("id");
        Map(Reveal.Member<Vote>("_votedate")).Column("vote_date");

        References(x => x.Post).Column("post_id").LazyLoad().Not.Nullable();
        References(x => x.User).Column("user_id").LazyLoad().Not.Nullable();
    }
}

邮政地图:

public class PostMap : ClassMap<Post>
{
    public PostMap()
    {
        DynamicUpdate();

        Table("post");
        Id(Reveal.Member<Post>("_id")).Column("id");
        Map(Reveal.Member<Post>("_content")).Column("content");
        References(x => x.User).Column("user_id").Not.Nullable().LazyLoad();
    }
}

用户地图

public class UserMap : ClassMap<User>
{
    public UserMap()
    {
        DynamicUpdate();

        Table("user");
        Id(Reveal.Member<User>("_id")).Column("id");
        Map(Reveal.Member<User>("_name")).Column("name");

        HasMany(x => x.Posts).KeyColumn("user_id").LazyLoad();
        HasMany(x => x.Votes).KeyColumn("user_id").LazyLoad();
    }
}

当我检索投票时:

var myvote = _votesRepository.GetVote(postid, userid);
int post_id = myvote.Post.Id;
int user_id = myvote.User.Id;

投票属性设置正确。 PostUser 引用属于 Castle.Proxies.PostProxyCastle.Proxies.UserProxy 类型,它们的属性是空的。 (post_iduser_id 设置为 0)

nHibernate 不应该延迟加载这些数据吗?

【问题讨论】:

  • 出于好奇,您为什么将私有字段 ("_id") 映射为 Id,而不是 Id 属性?虽然我真的不熟悉私有字段映射,但我想知道它是否适合延迟加载,特别是对于标识符。你试过用属性映射替换这些吗?
  • 因为我所有的实体都具有只读属性(不允许实体处于无效状态)。我按照建议用公共虚拟属性替换了私有属性,但仍然得到相同的结果。只有当我显然将 .Not.LazyLoad() 添加到所有映射时,它才有效。
  • 拥有实体类的相关代码将有助于理解您的问题。

标签: c# nhibernate fluent-nhibernate mapping lazy-loading


【解决方案1】:

你是对的 jbl,它根本不喜欢私有 id 字段。此更改解决了问题:

protected int _id;
public virtual int Id { get {return _id;} }

并从此更改所有类的映射:

Id(Reveal.Member<Vote>("_id")).Column("id");

到这里:

Id(x => x.Id).Column("id");

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-04-29
    • 2011-05-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-07-16
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多