diff --git a/NzbDrone.Core/CentralDispatch.cs b/NzbDrone.Core/CentralDispatch.cs index c53f96dc7..f4ce5ba1b 100644 --- a/NzbDrone.Core/CentralDispatch.cs +++ b/NzbDrone.Core/CentralDispatch.cs @@ -74,11 +74,11 @@ private static void BindKernel() Logger.Debug("Binding Ninject's Kernel"); _kernel = new StandardKernel(); - _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.MainConnectionString)).InRequestScope(); - _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.MainConnectionString, false)).WhenInjectedInto(); - _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.MainConnectionString, false)).WhenInjectedInto(); - _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.LogConnectionString, false)).WhenInjectedInto().InSingletonScope(); - _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.LogConnectionString)).WhenInjectedInto().InRequestScope(); + _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.MainConnectionString)).InTransientScope(); + //_kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.MainConnectionString, false)).WhenInjectedInto(); + //_kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.MainConnectionString, false)).WhenInjectedInto(); + //_kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.LogConnectionString, false)).WhenInjectedInto().InSingletonScope(); + _kernel.Bind().ToMethod(c => Connection.GetPetaPocoDb(Connection.LogConnectionString)).WhenInjectedInto().InSingletonScope(); } } diff --git a/NzbDrone.Core/Datastore/PetaPoco/PetaPoco.cs b/NzbDrone.Core/Datastore/PetaPoco/PetaPoco.cs index 3497f2794..e0027035f 100644 --- a/NzbDrone.Core/Datastore/PetaPoco/PetaPoco.cs +++ b/NzbDrone.Core/Datastore/PetaPoco/PetaPoco.cs @@ -342,7 +342,6 @@ public enum DBType // Common initialization private void CommonConstruct() { - _transactionDepth = 0; ForceDateTimesToUtc = true; EnableAutoSelect = true; @@ -407,6 +406,7 @@ public void CloseSharedConnection() OnConnectionClosing(_sharedConnection); _sharedConnection.Dispose(); _sharedConnection = null; + _transaction = null; } } @@ -441,15 +441,11 @@ public void BeginTransaction() // Use `using (var scope=db.Transaction) { scope.Complete(); }` to ensure correct semantics public void BeginTransaction(IsolationLevel? isolationLevel) { - _transactionDepth++; + OpenSharedConnection(); + _transaction = isolationLevel == null ? _sharedConnection.BeginTransaction() : _sharedConnection.BeginTransaction(isolationLevel.Value); + _transactionCancelled = false; + OnBeginTransaction(); - if (_transactionDepth == 1) - { - OpenSharedConnection(); - _transaction = isolationLevel == null ? _sharedConnection.BeginTransaction() : _sharedConnection.BeginTransaction(isolationLevel.Value); - _transactionCancelled = false; - OnBeginTransaction(); - } } @@ -473,15 +469,13 @@ void CleanupTransaction() public void AbortTransaction() { _transactionCancelled = true; - if ((--_transactionDepth) == 0) - CleanupTransaction(); + CleanupTransaction(); } // Complete the transaction public void CompleteTransaction() { - if ((--_transactionDepth) == 0) - CleanupTransaction(); + CleanupTransaction(); } // Helper to handle named parameters from object properties @@ -2524,7 +2518,6 @@ static T RecurseInheritedTypes(Type t, Func cb) DbProviderFactory _factory; IDbConnection _sharedConnection; IDbTransaction _transaction; - int _transactionDepth; bool _transactionCancelled; string _lastSql; object[] _lastArgs;