aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs')
-rw-r--r--MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs129
1 files changed, 80 insertions, 49 deletions
diff --git a/MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs b/MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs
index ee89c0f97..4d394d14a 100644
--- a/MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs
+++ b/MediaBrowser.Server.Implementations/Persistence/SqliteItemRepository.cs
@@ -80,6 +80,8 @@ namespace MediaBrowser.Server.Implementations.Persistence
private IDbCommand _deleteAncestorsCommand;
private IDbCommand _saveAncestorCommand;
+ private IDbCommand _updateInheritedRatingCommand;
+
private const int LatestSchemaVersion = 29;
/// <summary>
@@ -532,6 +534,11 @@ namespace MediaBrowser.Server.Implementations.Persistence
{
_saveStreamCommand.Parameters.Add(_saveStreamCommand, "@" + col);
}
+
+ _updateInheritedRatingCommand = _connection.CreateCommand();
+ _updateInheritedRatingCommand.CommandText = "Update TypedBaseItems set InheritedParentalRatingValue=@InheritedParentalRatingValue where Guid=@Guid";
+ _updateInheritedRatingCommand.Parameters.Add(_updateInheritedRatingCommand, "@InheritedParentalRatingValue");
+ _updateInheritedRatingCommand.Parameters.Add(_updateInheritedRatingCommand, "@Guid");
}
/// <summary>
@@ -2011,55 +2018,79 @@ namespace MediaBrowser.Server.Implementations.Persistence
public async Task UpdateInheritedValues(CancellationToken cancellationToken)
{
- //await _writeLock.WaitAsync(cancellationToken).ConfigureAwait(false);
-
- //IDbTransaction transaction = null;
-
- //try
- //{
- // transaction = _connection.BeginTransaction();
-
- // using (var cmd = _connection.CreateCommand())
- // {
- // cmd.CommandText = "update TypedBaseItems set InheritedParentalRatingValue = (select Max(ParentalRatingValue, (select COALESCE(MAX(ParentalRatingValue),0) from TypedBaseItems as T where guid in (Select AncestorId from AncestorIds where ItemId=T.guid))))";
-
- // cmd.Transaction = transaction;
- // cmd.ExecuteNonQuery();
-
- // cmd.ExecuteNonQuery();
- // }
-
- // transaction.Commit();
- //}
- //catch (OperationCanceledException)
- //{
- // if (transaction != null)
- // {
- // transaction.Rollback();
- // }
-
- // throw;
- //}
- //catch (Exception e)
- //{
- // _logger.ErrorException("Error running query:", e);
-
- // if (transaction != null)
- // {
- // transaction.Rollback();
- // }
-
- // throw;
- //}
- //finally
- //{
- // if (transaction != null)
- // {
- // transaction.Dispose();
- // }
-
- // _writeLock.Release();
- //}
+ var newValues = new List<Tuple<Guid, int>>();
+
+ using (var cmd = _connection.CreateCommand())
+ {
+ cmd.CommandText = "select Guid,InheritedParentalRatingValue,(select Max(ParentalRatingValue, (select COALESCE(MAX(ParentalRatingValue),0) from TypedBaseItems where guid in (Select AncestorId from AncestorIds where ItemId=Outer.guid)))) as NewInheritedParentalRatingValue from typedbaseitems as Outer where InheritedParentalRatingValue <> NewInheritedParentalRatingValue";
+
+ using (var reader = cmd.ExecuteReader(CommandBehavior.SequentialAccess | CommandBehavior.SingleResult))
+ {
+ while (reader.Read())
+ {
+ var id = reader.GetGuid(0);
+ var newValue = reader.GetInt32(2);
+
+ newValues.Add(new Tuple<Guid, int>(id, newValue));
+ }
+ }
+ }
+
+ if (newValues.Count == 0)
+ {
+ return;
+ }
+
+ await _writeLock.WaitAsync(cancellationToken).ConfigureAwait(false);
+
+ IDbTransaction transaction = null;
+
+ try
+ {
+ transaction = _connection.BeginTransaction();
+
+ foreach (var item in newValues)
+ {
+ _updateInheritedRatingCommand.GetParameter(0).Value = item.Item1;
+ _updateInheritedRatingCommand.GetParameter(1).Value = item.Item2;
+
+ _updateInheritedRatingCommand.Transaction = transaction;
+ _updateInheritedRatingCommand.ExecuteNonQuery();
+
+ _updateInheritedRatingCommand.ExecuteNonQuery();
+ }
+
+ transaction.Commit();
+ }
+ catch (OperationCanceledException)
+ {
+ if (transaction != null)
+ {
+ transaction.Rollback();
+ }
+
+ throw;
+ }
+ catch (Exception e)
+ {
+ _logger.ErrorException("Error running query:", e);
+
+ if (transaction != null)
+ {
+ transaction.Rollback();
+ }
+
+ throw;
+ }
+ finally
+ {
+ if (transaction != null)
+ {
+ transaction.Dispose();
+ }
+
+ _writeLock.Release();
+ }
}
private static Dictionary<string, string[]> GetTypeMapDictionary()