0

每当我想删除对象的层次结构时,这意味着一个Menu对象中包含另一个Menu对象。但是,如果删除单个对象(内部没有任何对象),它可以正常工作。我收到以下错误:

保存不为其关系公开外键属性的实体时发生错误。EntityEntries 属性将返回 null,因为无法将单个实体标识为异常源。通过在实体类型中公开外键属性,可以更轻松地在保存时处理异常。有关详细信息,请参阅 InnerException。

这就是我的类型:

 public class Menu
    {
        public string Reference { get; set; }

        [JsonProperty("text")]
        [MaxLength(30), MinLength(2)]
        public string DisplayText { get; set; }

        [MaxLength(150)]
        public string HyperLink { get; set; }

        private List<Menu> menus;
        [JsonProperty("items")]
        public virtual List<Menu> Menus
        {
            get 
            {
                if (menus == null || menus.Count == 0)
                {
                    return null;
                }

                return menus;
            }
            set { menus = value; }
        }
    }

配置:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
   {
       modelBuilder.Entity<Menu>().HasKey(k => k.Reference);
   }

以下是我删除的方式:

List<Menu> menu = JsonConvert.DeserializeObject<List<TMenu>>(Menu);

            using (DataContext context = new DataContext())
            {
                if (context.Menus.Count() != 0)
                {
                    foreach (var item in menu)
                    {
                        Menu deleteMenu = context.Menus.Where(f => f.Reference == item.Reference).FirstOrDefault();
                        context.Menus.Remove(deleteMenu);
                    }

                    context.SaveChanges();
                }
            }

我非常感谢您对此提出建议。

4

1 回答 1

0

长话短说,即使我可以阅读 PostGres,SQL Server 也无法进行递归删除。无论如何,我必须在手动进行递归删除的表上创建一个触发器。

于 2013-11-02T20:09:46.260 回答