我有一个由SQL Server DB支持的.Net服务器应用程序。我正在使用nHibernate(流畅)来处理所有数据库操作。我面临严重的性能和并发问题,显然是因为我不是nHibernate和ORM的专家(甚至不是很接近)。
我有一些需要存储在数据库中的数据和一些不存储的数据。例如,我有 members class
(显然需要在数据库中保留),我还有 logged-in-members class
(只有运行时数据,不需要持久化)。也许我的榜样不是最好的,但我认为它证明了我的情况。登录成员对象将具有Member类型的属性,以便两个类之间存在连接。
有没有办法避免持久化某些类但仍然能够拥有一个完整的图形,包括持久性和“内存中”对象?
答案 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);
}