entity-framework-core - Asp.Net Core 3.1 Invalid column name 'Column Name' 错误信息
问题描述
我将 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
解决方案
推荐阅读
- javascript - 根据另一个状态道具的 Onchange 更改组件状态道具
- excel - 删除与清除内容 VB.net
- powershell - 将字符串转换为 PowerShell 日期和时间格式
- python - 如何从网站访问 Python 中的本地文件
- magnolia - Magnolia - 跨领域验证
- javascript - 如何使用 asp.net 4.0 在网格视图中显示 html 预览
- javascript - 用javascript点击计数器
- java - 如何使用 jUnit 对 Servlet 过滤器进行单元测试?ServletRequest、ServletResponse、FilterChain
- c# - 如何更改字体样式或覆盖 Xamarin.Android 中完整应用程序的默认字体样式
- android - Ionic ios 应用程序在 android 上真的很慢但很快