从自连接类型中删除
本文关键字:删除 类型 自连接 | 更新日期: 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。无论如何,我必须在手动进行递归删除的表上创建一个触发器。