我第一次尝试使用导航属性而不是连接。我无法通过左外连接来完成通常情况下的工作。在下面的示例中,我只返回外键为非null的结果。我需要回复所有结果。我错过了什么?
public class User
{
[Key]
public int UserID {get;set;}
public String Name {get;set;}
}
public class Shipment
{
[Key]
public int ShipmentID {get;set;}
public int? SignedForByID {get;set;}
[ForeignKey("SignedForByID")]
public virtual User SignedForBy{get;set;}
}
导航属性映射:
Shipment.HasOptional(x=> x.SignedForBy).WithMany()
.HasForeignKey(y=> y.SignedForByID).WillCascadeOnDelete(false);
查询:
var data = (from s in context.Set<Shipment>()
select new {
ShipmentID = s.ShipmentID,
SignedForBy = s.SignedForBy
});
答案 0 :(得分:1)
此示例中未显示此问题。映射由辅助类生成。在某些情况下,助手类使用.HasRequired()方法而不是.HasOptional()错误地映射导航属性。更正映射类已修复该问题。