NHibernate:读取未提交的列
本文关键字:提交 读取 NHibernate | 更新日期: 2024-11-07 18:14:56
是否可以读取(即选择)同一事务中的列,它们被写入数据库?
我的代码如下所示:
using (IGenericTransaction trans = m_GenericSession.BeginTransaction())
{
//persist a column to table tExample with Id = 1
WriteSubItems();
trans.Commit();
}
public void WriteSubItems()
{
IDbTransaction trans = GetTransaction();
//SELECT column from tExample with Id = 1
}
其中 WriteSubItems 执行一些逻辑,该逻辑基于读取之前在事务中写入的列。
我试过了:
public IDbTransaction GetTransaction()
{
IDbCommand cmd = Session.Connection.CreateCommand())
cmd .Connection = Session.Connection;
Session.Transaction.Enlist(cmd );
return command.Transaction;
}
但没有成功。尝试读取 tExample 总是返回空结果集。当我调用 Session.Transaction.Commit() 时,所有行都添加到数据库中,但仍然没有将事务正确传递给命令。交易或未在那里使用
如果要读取在事务中所做的更新,如果您使用的是执行更新的同一会话,则这些更新应该已经在内存中可用。 但是,如果要通过另一个会话读取未提交的行,则可能必须在事务中使用不同的隔离级别。
ITransaction transaction = session.BeginTransaction(System.Data.IsolationLevel.<insert correct isolation level here>);
在此处阅读有关隔离级别的更多信息:https://msdn.microsoft.com/en-us/library/system.data.isolationlevel%28v=vs.110%29.aspx