【发布时间】:2018-11-29 14:09:23
【问题描述】:
该方法应该从服务器接收数据,检查是否添加了新令牌,如果有,则将它们添加到数据库中。如果令牌已存在,请更新其状态但不要在表中添加新行。这是我目前写的代码。
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();
}
现在,这段代码完成了它应该做的事情,但是它非常慢。我将如何优化它?
【问题讨论】:
-
这是ef核心吗?
-
_tokenService 是外部服务吗(例如调用 db 或 api 来获取此令牌)?
-
@Silvermind just ef 6
-
如果您使用的是 EF。如果实体已经在 DB SaveChanges 中,则无需执行 AddOrUpdate
-
@Dimitar _tokenService 调用 db,server 调用 api
标签: c# .net performance entity-framework linq