簡體   English   中英

實體框架6多個數據上下文共享事務

[英]Entity Framework 6 Multiple Datacontext Sharing a transaction

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);
    }
}

您沒有指定上下文是否連接到同一數據庫。

如果數據庫不同,則需要避免BeginTransactionUseTransaction並將代碼instread封裝在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)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM