[解決済み] Entity Framework 6 トランザクションのロールバック
質問
EF6では、新しいトランザクションがあり、次のように使用することができます。
using (var context = new PostEntityContainer())
{
using (var dbcxtransaction = context.Database.BeginTransaction())
{
try
{
PostInformation NewPost = new PostInformation()
{
PostId = 101,
Content = "This is my first Post related to Entity Model",
Title = "Transaction in EF 6 beta"
};
context.Post_Details.Add(NewPost);
context.SaveChanges();
PostAdditionalInformation PostInformation = new PostAdditionalInformation()
{
PostId = (101),
PostName = "Working With Transaction in Entity Model 6 Beta Version"
};
context.PostAddtional_Details.Add(PostInformation);
context.SaveChanges();
dbcxtransaction.Commit();
}
catch
{
dbcxtransaction.Rollback();
}
}
}
物事が横道にそれたとき、ロールバックは実際に必要なのでしょうか?Commit の説明では、" Commits the underlying store transaction." と書かれているので、気になります。
一方、ロールバックの説明では、"基礎となるストア トランザクションをロールバックします."。
なぜなら、Commit が呼び出されないと、以前に実行されたコマンドは保存されないように見えるからです (これは論理的だと思います)。しかし、もしそうであれば、Rollback 関数を呼び出す理由は何でしょうか。EF5ではTransactionScopeを使いましたが、Rollback関数がなく(Completeのみ)、これは論理的だと思いました。MS DTCの理由のために、私はもうTransactionScopeを使用することはできませんが、私はまた、上記の例のようなトライキャッチを使用することはできません(すなわち、私はコミットだけが必要です)。
どのように解決するのですか?
を呼び出す必要はありません。
Rollback
を手動で呼び出す必要はありません。
using
ステートメントを使用しているためです。
DbContextTransaction.Dispose
メソッドの末尾で呼び出されます。
using
ブロックの最後で呼び出されます。そして、トランザクションが正常にコミットされなかった場合(呼び出されなかったり、例外が発生した場合)、自動的にロールバックされます。以下は
SqlInternalTransaction.Dispose
メソッド (
DbContextTransaction.Dispose
は、SqlServer プロバイダを使用する場合、最終的にこれに委譲されます)。
private void Dispose(bool disposing)
{
// ...
if (disposing && this._innerConnection != null)
{
this._disposing = true;
this.Rollback();
}
}
ほら、これは
_innerConnection
が NULL でないなら、トランザクションをロールバックします (コミットされた場合。
_innerConnection
はNULLになる)。それでは
Commit
が何をするか見てみましょう。
internal void Commit()
{
// Ignore many details here...
this._innerConnection.ExecuteTransaction(...);
if (!this.IsZombied && !this._innerConnection.IsYukonOrNewer)
{
// Zombie() method will set _innerConnection to null
this.Zombie();
}
else
{
this.ZombieParent();
}
// Ignore many details here...
}
internal void Zombie()
{
this.ZombieParent();
SqlInternalConnection innerConnection = this._innerConnection;
// Set the _innerConnection to null
this._innerConnection = null;
if (innerConnection != null)
{
innerConnection.DisconnectTransaction(this);
}
}
関連
-
[解決済み】トランスポート接続からデータを読み取れない:既存の接続は、リモートホストによって強制的に閉じられました。
-
[解決済み】Entity FrameworkからのSqlException - セッション内で他のスレッドが動作しているため、新しいトランザクションは許可されません。
-
[解決済み】値をNULLにすることはできません。パラメータ名:source
-
[解決済み] 不変量名 'System.Data.SqlClient' を持つ ADO.NET プロバイダに対応する Entity Framework プロバイダが見つかりませんでした。
-
[解決済み] Entity Framework 5 レコードを更新する
-
[解決済み] Entity FrameworkとLINQ to SQLの比較
-
[解決済み] Entity Frameworkにおける最速の挿入方法
-
[解決済み] Entity Frameworkで生成されたSQLを表示するにはどうすればよいですか?
-
[解決済み] Entity Framework - 複数レベルのプロパティを含める
-
[解決済み】Entity Frameworkプロバイダタイプをロードできませんでしたか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Excel "外部テーブルが期待された形式ではありません。"
-
[解決済み】統合マネージドパイプラインモードで適用されないASP.NETの設定が検出された
-
[解決済み】C# - パスに不正な文字がある場合
-
[解決済み】MetadataException: 指定されたメタデータ・リソースをロードできない
-
[解決済み】HRESULTからの例外:0x800A03ECエラー
-
[解決済み】 C# 条件演算子エラー 代入、call、increment、decrement、await、new object 式のみ文として使用可能です。
-
[解決済み】URLから画像をダウンロードする方法
-
[解決済み】プロセスが実行されているかどうかを知るには?
-
[解決済み] トランザクションを使用するか、SaveChanges(false)とAcceptAllChanges()を使用するか?
-
[解決済み] データベース(SQL Serverなど)にトランザクションをコミットしないとどうなるのでしょうか?