Asp.Net Core 3.1 无效的列名“列名”错误消息

问题描述

我将 ASP.NET Core 3.1 API 与 Entity Framework Core 一起使用,我有两个表,第一个CategoryType,另一个CategoryMaster - 像这样:

public class CategoryType
{
    [Key]
    public int TypeId { get; set; }
    public string TypeName { get; set; }
    public string TypeValue { get; set; }
}

public class CategoryMaster
{
    [Key]
    public int CategoryID { get; set; }
    public string CategoryName { get; set; }
    public string CategoryCode { get; set; }
    //Foreign Key data
    [Column("CategoryType")]
    public string CategoryTypeValue { get; set; }
    [ForeignKey("TypeValue")]
    public CategoryType CategoryType { get; set; }

    [DefaultValue(0)]
    public bool? DeleteFlag { get; set; }
}

DbContext 如下:

public virtual DbSet<CategoryType> CategoryType { get; set; }
public virtual DbSet<CategoryMaster> CategoryMaster { get; set; }

TypeValue 属性是这两个表之间的外键,我无法更改它,因为我正在从旧系统迁移到新系统,但是,问题实体框架核心正在自动检测该表Id 键作为外键,即 TypeId,因此我收到此错误

无效的列名“TypeValue”

搜索了很多领域并尝试申请,但没有得到任何结果:

如何将外键与非主键关联起来?

或者有一个简单的问题:如何使用 Entity Framework Core 使 CategoryTypeValue 表中的 CategoryMaster 成为 CategoryType 表的外键?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)