public TotalRelationStatistics GetByUniqueKey(TotalRelationStatisticsUniqueKey key) { using (var context = CreateContextFunc()) { return(context.TotalRelationStatistics.Where(x => x.DatabaseID == key.DatabaseID && x.Date == key.Date && x.RelationID == key.RelationID).SingleOrDefault()); } }
private void PersistTotalRelationStatistics(TotalRelationStatistics newStatistics) { var repository = repositories.GetTotalRelationStatisticsRepository(); var uniqueKey = new TotalRelationStatisticsUniqueKey() { DatabaseID = newStatistics.DatabaseID, Date = newStatistics.Date, RelationID = newStatistics.RelationID }; var oldStatistics = repository.GetByUniqueKey(uniqueKey); if (oldStatistics == null) { repository.Create(newStatistics); } else { TotalRelationStatisticsMergeUtility.ApplySample(oldStatistics, newStatistics); repository.Update(oldStatistics); } }