实体集'SelectListItems'基于未定义键的类型'SelectListItem'



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();

相关内容

最新更新