using(var Db = new Framework_DbContext())
{
var DbContextTransaction = Db.Database.BeginTransaction(IsolationLevel.ReadUncommitted);
using (var db = new DocumentLibDbContext())
{
//**How to use the above DbContextTransaction??**
db.Database.UseTransaction(DbContextTransaction.UnderlyingTransaction);
}
}
答案 0 :(得分:1)
您没有指定您的上下文是否连接到同一个数据库。
如果数据库不同,则需要避免使用BeginTransaction
和UseTransaction
,并将代码包装在TransactionScope
中。
假设它们都连接到同一个数据库,则不指定是使用EDMX还是使用Code First。我在使用EDMX时遇到了同样的问题,花了一整天的时间进行反复试验,并最终找到了解决方案。
var workspace = new MetadataWorkspace(new[] { "res://*/" }, new[] { Assembly.GetExecutingAssembly() });
using (var connection = new SqlConnection("data source=.;initial catalog=MultpleEdmxTest;integrated security=True;MultipleActiveResultSets=True"))
{
using (var entityConnection1 = new EntityConnection(workspace, connection, false))
{
using (var entityConnection2 = new EntityConnection(workspace, connection, false))
{
connection.Open();
using (var transaction = connection.BeginTransaction())
{
using (var schema1Entities = new Schema1Entities(entityConnection1))
{
schema1Entities.Database.UseTransaction(transaction);
// code goes here
schema1Entities.SaveChanges();
}
using (var schema2Entities = new Schema2Entities(entityConnection2))
{
schema2Entities.Database.UseTransaction(transaction);
// code goes here
schema2Entities.SaveChanges();
}
transaction.Commit();
}
}
}
}
您可以在部分类中定义额外的构造函数,如下所示:
partial class Schema1Entities
{
public Schema1Entities(DbConnection connection) : base(connection, false) { }
}
其中false表示您手动打开和关闭连接。
作为奖励,你现在只需要配置中的一个连接字符串,它不包括通常附带的所有无用的EF垃圾(metadata = res:// * / blabla)。