首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何有效地编辑数据库中的数据?

如何有效地编辑数据库中的数据?
EN

Stack Overflow用户
提问于 2018-11-29 14:09:23
回答 1查看 102关注 0票数 0

该方法应该从服务器接收数据,检查是否添加了新令牌,如果有,则将它们添加到数据库中。如果令牌已经存在,则更新其状态,但不要在表中添加新行。这是我到目前为止写的代码。

代码语言:javascript
复制
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操作。

代码语言:javascript
复制
public void AddToken(Token token)
        {
            _dbContext.Tokens.AddOrUpdate(token);
            //_dbContext.SaveChanges();
        }

现在,这段代码完成了它应该做的事情,但是它非常慢。我将如何优化它呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-11-29 14:17:32

dbTokens.Where(x => x.Symbol == token.Symbol)为IEnumerable

所以每次你在循环上调用它时他都会加载它。在循环之前将其存储在列表中

代码语言:javascript
复制
List<Token> dbTokens = _tokenService.GetAllTokens().ToList()
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53540885

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档