我在更新Entity Framework6中的值时遇到了麻烦,我已经彻底地在互联网上寻找了答案,但似乎我做的一切都很好,但我似乎不能让它工作。
值得一提的是,将实体添加到数据库中工作得很好,这意味着我可以将项目中的产品/用户添加到数据库中,但不能更新它们。这是家庭作业。
public bool ChangeAccountStatus(long userID, bool isUserActive)
{
User userToChange = GetUserById(userID); // Gets the user whose values I want to change.
using (var context = new ShopContext())
{
if (userToChange != null)
{
if (isUserActive)
{
userToChange.IsActive = false;
context.SaveChanges();
}
else
{
userToChange.IsActive = true;
context.SaveChanges();
}
return true;
}
return false;
}
}
如果我使用linq查找我想要更改其值的用户,我可以使更新生效,但我不希望在我的项目中有太多的代码重复,并且我在许多其他函数中使用相同的linq (function GetUserById)。我是否需要使用linq从数据库访问用户,而不是使用我为避免代码重复而创建的函数?这是GetUserById函数:
public User GetUserById(long userId)
{
using (var context = new ShopContext())
{
var userToFind = context.UsersTable
.Where((u) => u.Id == userId).FirstOrDefault();
if (userToFind != null)
return userToFind;
else
return null;
}
}
https://stackoverflow.com/questions/50751496
复制相似问题