c# – 检查实体是否在Code First中的其他实体中有引用

您是否知道我如何确定某个实体是否在其他实体中引用了该实体?

如果我用sql语言说话,我的意思是,我可以检查主键是否是某些表中的外键.

我想将实体对象标记为IsDeleted(它是一个属性),只要它没有从另一个表中引用它,我想避免物理删除.

谢谢,

解决方法

对于简单的情况,您可以使用 Any运算符检查是否存在外键:

public class Country
{
    public int ID { get; set; }
    public string Name { get; set; }
}

public class City
{
    public int ID { get; set; }
    public int CountryID { get; set; }
    public string Name { get; set; }
}

public bool IsCountryReferenced(Country country,IEnumerable<City> cities)
{
    return cities.Any(city => city.CountryID == country.ID);
}

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...