Как эффективно редактировать данные в базе данных? - PullRequest
0 голосов
/ 29 ноября 2018

Метод должен получать данные с сервера, проверять, были ли добавлены новые токены, и, если они есть, добавить их в базу данных.Если токен уже существует, обновите его статус, но не добавляйте новую строку в таблицу.Это код, который я написал до сих пор.

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();
        }

Теперь этот код делает то, что онПредполагается, однако это очень медленно.Как мне его оптимизировать?

1 Ответ

0 голосов
/ 29 ноября 2018

dbTokens.Where (x => x.Symbol == token.Symbol) равен IEnumerable

Поэтому он будет загружать его каждый раз, когда вы вызываете его в цикле.Хранить в списке перед циклом

List<Token> dbTokens = _tokenService.GetAllTokens().ToList()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...