![](/img/trans.png)
[英]The entity type 'Microsoft.AspNet.Identity.EntityFramework.IdentityUserLogin<string>' requires a key to be defined
[英]cannot convert from 'string' to 'Microsoft.AspNet.Identity.EntityFramework.IdentityUserRole
我對更新數據庫還是比較陌生的,並且我構建了以下代碼,用新角色替換了用戶角色。 我在這個問題上得到了錯誤。
public void UpdateRole(string id, string newRoleID)
{
var user = Users.FirstOrDefault(u => u.Id == id);
var oldRoleId = user.Roles.FirstOrDefault().RoleId;
if (user != null && oldRoleId != newRoleID)
{
user.Roles.Remove(oldRoleId);
user.Roles.Add(newRoleID);
}
}
有人可以解釋為什么我遇到這個錯誤嗎? 我沒有嘗試轉換任何東西。 我試圖刪除指定用戶ID的RoleId內容,並將其替換為從我的發布操作發送的新ID。
在將string
值(即newRoleID
)傳遞給它時, user.Roles.Add
方法將使用IdentityUserRole
對象。 您需要在代碼中進行以下更改:
user.Roles.Add(new IdentityUserRole { RoleId = newRoleID });
編輯
Remove
方法也需要一個IdentityUserRole
對象。 但請注意,它也必須附加到上下文中。 最簡單的方法是通過以下代碼:
var user = Users.FirstOrDefault(u => u.Id == id);
var oldRole = user.Roles.FirstOrDefault();
if (user != null && oldRole.RoleId != newRoleID)
{
user.Roles.Remove(oldRole);
user.Roles.Add(new IdentityUserRole { RoleId = newRoleID });
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.