从自连接类型中删除

本文关键字:删除 类型 自连接 | 更新日期: 2023-09-27 18:31:59

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

保存不公开外键的实体时出错 其关系的属性。属性将 返回 null,因为无法将单个实体标识为源 的例外。可以在保存时处理异常 通过在实体类型中公开外键属性,可以更轻松地实现。看 内部异常了解详细信息。

这是我的类型:

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

我真的很感激对此的建议。

从自连接类型中删除

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