将持久性与易失性数据混合

时间:2012-10-22 14:04:50

标签: .net nhibernate orm persistent

我有一个由SQL Server DB支持的.Net服务器应用程序。我正在使用nHibernate(流畅)来处理所有数据库操作。我面临严重的性能和并发问题,显然是因为我不是nHibernate和ORM的专家(甚至不是很接近)。

我有一些需要存储在数据库中的数据和一些不存储的数据。例如,我有 members class (显然需要在数据库中保留),我还有 logged-in-members class (只有运行时数据,不需要持久化)。也许我的榜样不是最好的,但我认为它证明了我的情况。登录成员对象将具有Member类型的属性,以便两个类之间存在连接。

有没有办法避免持久化某些类但仍然能够拥有一个完整的图形,包括持久性和“内存中”对象?

1 个答案:

答案 0 :(得分:0)

我不确定对象图是怎样的,但为什么不让会话找出改变了什么呢?

void DoSomethingWithMembers()
{
    // if session which loaded the members is not open anymore
    foreach (var member in loggedInMembers.Select(loggedInMember => loggedInMember.Member))
    {
        session.Lock(member, LockMode.None); // reattach to session
    }
    // end if

    // make changes to the (loggedIn)members

    session.Flush(); // will persist any changes to a member
}

更新:作为对评论的回应,类似这样的

public AuthenticationResult Authenticate(string username, string password)
{
    if (loggedInUsers.ContainsKey(username))
        return AuthenticationResult.AlreadyLoggedIn;

    using (var session = OpenSession())
    {
        var member = session.Query<Member>().Where(m => m.Name == username).FirstOrDefault();
    }

    if (member == null)
        return AuthenticationResult.NoUser;

    if (member.Password != password)
        return AuthenticationResult.WrongPassword;

    loggedInUsers.Add(username, new LoggedInMember(DateTime.Now, member));

    var dto = mapper.Map<Member, MemberDto>(member);
    return new AuthenticationResult(dto);
}

public void Update(ICollection<MemberDto> dtos)
{
    using (var session = OpenSession())
    {
        foreach (var dto in dtos)
        {
            Update(session, dto);
        }
        session.Flush();
    }
}

void Update(ISession session, MemberDto dto)
{
    LoggedInMember liMember;
    if (!loggedInUsers.TryGetValue(dto.Name, out liMember)
        throw new AuthException("not logged in")

    session.Lock(li.Member, LockMode.None); // attach

    mapper.Map<Member, MemberDto>(li.Member, dto);
}