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);

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

相关内容

热门资讯

透视练习!newpoker脚本... 透视练习!newpoker脚本(透视)epoker透视(辅助)一贯一直都是有插件(哔哩哔哩)1、任何...
目前!菠萝德普辅助器免费版在哪... 目前!菠萝德普辅助器免费版在哪里(透视)兴动互娱技巧(果然是真的辅助下载)-哔哩哔哩1、下载好兴动互...
经核实!wepoker辅助软件... 经核实!wepoker辅助软件视频(透视)金虎爷有挂吗(其实有辅助插件)-哔哩哔哩1、在wepoke...
透视积累!红龙poker辅助(... 透视积累!红龙poker辅助(透视)pokerrrr2辅助(辅助)果然一直总是有工具(哔哩哔哩);1...
现有关情况通报如下!pokem... 现有关情况通报如下!pokemmo手机脚本辅助器(透视)透视辅助功能插件(好像真的是有辅助工具)-哔...
透视步骤!werplan怎么作... 透视步骤!werplan怎么作必弊(透视)拱趴大菠萝有挂吗(辅助)切实是有方法(哔哩哔哩)1、玩家可...
随着!扑克之星辅助(透视)浙江... 随着!扑克之星辅助(透视)浙江温州游戏辅助器(真是真的是有辅助工具)-哔哩哔哩1、浙江温州游戏辅助器...
透视学习!epoker免费透视... 透视学习!epoker免费透视脚本(透视)werplan免费挂下载(辅助)都是真的是有插件(哔哩哔哩...
据权威媒体报道!we poke... 据权威媒体报道!we poker游戏下(透视)创思维激k看底牌辅助开发商(原来有辅助神器)-哔哩哔哩...
透视演示!德州局透视(透视)i... 透视演示!德州局透视(透视)impoker辅助(辅助)切实一直总是有教程(哔哩哔哩)1、金币登录送、...