Метод должен получать данные с сервера, проверять, были ли добавлены новые токены, и, если они есть, добавить их в базу данных.Если токен уже существует, обновите его статус, но не добавляйте новую строку в таблицу.Это код, который я написал до сих пор.
IEnumerable<Token> serverTokens = JsonConvert.DeserializeObject<IEnumerable<Token>>
(server.GetTokens().Content);
IEnumerable<Token> dbTokens = _tokenService.GetAllTokens();
foreach (var token in serverTokens)
{
var dbToken = dbTokens.Where(x => x.Symbol == token.Symbol).FirstOrDefault();
if (dbToken != null)
{
Token editedToken = dbToken;
editedToken.UpdatedOn = DateTime.Now;
editedToken.Active = token.Active;
_tokenService.AddToken(editedToken);
}
else
{
token.UpdatedOn = DateTime.Now;
_tokenService.AddToken(token);
}
}
dbContext.SaveChanges();
Метод AddToken
- это простая операция AddOrUpdate
.
public void AddToken(Token token)
{
_dbContext.Tokens.AddOrUpdate(token);
//_dbContext.SaveChanges();
}
Теперь этот код делает то, что онПредполагается, однако это очень медленно.Как мне его оптимизировать?