Controller
public JsonResult menulist()
{
try
{
if (Session["User_Type"].ToString() != null)
{
var menu = db.menuitems.ToList().Where(d => d.HasAccess.Contains(Session["User_Type"].ToString())).OrderBy(d=>d.Name);
return new JsonResult { Data = menu, JsonRequestBehavior = JsonRequestBehavior.AllowGet };
}
return new JsonResult { Data = "", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
}
catch (Exception ex)
{
return new JsonResult { Data = "", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
}
}
型
public class MenuItem
{
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Key]
public int MenuItemId { get; set; }
public string Name { get; set; }
public string ActionName { get; set; }
public string ControllerName { get; set; }
public string Url { get; set; }
public bool Disable { get; set; }
public string HasAccess { get; set; }
public int ParentMenuId { get; set; }
}
上下文
public DbSet<MenuItem> menuitems { get; set; }
我在数据库中自动生成了MenuItemId
字段,因此我在模型中将其定义为键和标识。 我仍然收到Key not defined
错误,并且"选择列表项"没有定义键。
错误
在模型生成过程中检测到一个或多个验证错误: Demo.Context.SelectListItem: : EntityType 'SelectListItem' 没有定义键。定义此实体类型的键。 SelectListItems:EntityType:EntitySet 'SelectListItems' 基于未定义键的类型 'SelectListItem'。
你能试试这个吗?
var menu = db.menuitems.Where(d => d.HasAccess.Contains(Session["User_Type"].ToString())).OrderBy(d=>d.Name).ToList();