ASP.NET EF CORE: 由两个外键组成的复合键未正确评估
创始人
2024-09-16 06:00:15
0

在ASP.NET EF Core中,使用两个外键组成的复合键时,有时会遇到评估错误的问题。以下是解决此问题的一种方法:

  1. 首先,确保在模型类中正确定义了复合键。例如,假设有两个外键属性ForeignKey1ForeignKey2,并且它们共同组成了复合键。
public class YourEntity
{
    public int ForeignKey1 { get; set; }
    public int ForeignKey2 { get; set; }
    
    // Other properties
    
    // Define the composite key
    [Key]
    public int CompositeKey => HashCode.Combine(ForeignKey1, ForeignKey2);
    
    // Navigation properties for the foreign keys
    public ForeignKey1Entity ForeignKey1Entity { get; set; }
    public ForeignKey2Entity ForeignKey2Entity { get; set; }
}
  1. 在DbContext类中,使用HasAlternateKey方法来配置复合键。这将告诉EF Core将这两个外键属性作为复合键。
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity()
        .HasAlternateKey(e => new { e.ForeignKey1, e.ForeignKey2 });
}
  1. 确保在查询中正确使用复合键。例如,如果要根据复合键检索实体,可以使用Find方法。
var entity = dbContext.YourEntities.Find(foreignKey1Value, foreignKey2Value);

这样,就可以正确评估由两个外键组成的复合键了。

相关内容

热门资讯

透视脚本(微扑克辅助器ios)... 1、透视脚本(微扑克辅助器ios)wpk微扑克真的有助辅吗(详细辅助我来教教你)切实是真的有挂。2、...
透视挂(aapoker透明挂)... 自定义系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是想分享给你好...
辅助透视(wpk提高胜率)德州... 辅助透视(wpk提高胜率)德州透视辅助(详细辅助透明挂教程)素来有挂1、不需要AI权限,帮助你快速的...
透视科技(wpk辅助挂)扑克时... 透视科技(wpk辅助挂)扑克时间可以控制吗(详细辅助透明挂教程)往昔真的有挂;无聊就玩这款真的有辅助...
透视总结(aapoker透视辅... 1、透视总结(aapoker透视辅助)wpk俱乐部外挂(详细辅助wepoke教程)原先有挂;详细教程...
透视辅助(WePoKe透明挂)... 自定义系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是想分享给你好...
透视数据(wpk有外挂)德扑保... 透视数据(wpk有外挂)德扑保险计算器(详细辅助德州教程)原生有挂;无聊就玩这款真的有辅助,无限炸弹...
wepoke ai辅助!德扑之... 1、wepoke ai辅助!德扑之星创建房间设置,(线上德州)好像是有挂(详细辅助详细教程)(UU ...
透视数据(wepokeai机器... 透视数据(wepokeai机器人)wpk长期盈利打法(详细辅助扑克教程)总是有挂1、许多玩家不知道辅...
wepoke辅助!wopoke... WePoker透视辅助版本稳定性对比与推荐‌:wepoke辅助!wopoker辅助v3.0,(手机德...