Entity Framework 7における明示的なトランザクション

asp.net-core c# entity-framework-core

質問

誰もEntity Framework 7で明示的なトランザクションを作成する方法を知っていますか?私が見つけたすべての情報は、EFのバージョン6を参照しています。ドキュメントも非常に不完全です、誰かがそれの例を提供することができますか?

私はdbContextを持っていると私はエンティティを削除する必要があり、それは関連オブジェクトですし、再度それらを挿入しますが、同じトランザクションで、私はいつも "バージョン"の行があります。

受け入れられた回答

トランザクション機能は、RC1のみで始まるEF7に含まれています( 文を参照)。 .SaveChanges() (または.SaveChangesAsync() )の呼び出しは、自動トランザクションを使用する必要があります。次に、エンティティのいくつかのアイテムの状態が、たとえば、以前に「削除済み」としてマークされていると仮定します。

1つは、データベース内のいくつかのフラグメントをラップすることによって、トランザクションを明示的に開始することができます。

using (context.Database.BeginTransaction()) {
    /*do something*/
}

トランザクションは、ブロックのusing終了時に.Dispose()呼び出しによってコミットされます。代わりに使うことができる

using (var transaction = await context.Database.BeginTransactionAsync()) {
    /*do something*/
    /*one can call
       transaction.Rollback() or transaction.Commit()
      explicitly in the code */
}

一般的には、以前のバージョンのEntity Frameworkのように見えるはずです。たとえば、記事を参照してください。



Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ