如何解决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”
我搜索了很多领域并尝试申请,但没有得到任何结果:
- https://www.entityframeworktutorial.net/code-first/foreignkey-dataannotations-attribute-in-code-first.aspx
- https://www.learnentityframeworkcore.com/configuration/one-to-many-relationship-configuration
- https://gavilan.blog/2019/04/14/entity-framework-core-foreign-key-linked-with-a-non-primary-key/
如何将外键与非主键关联起来?
或者有一个简单的问题:如何使用 Entity Framework Core 使 CategoryTypeValue
表中的 CategoryMaster
成为 CategoryType
表的外键?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。