jas*_*son 3 c# many-to-many entity-framework ef-code-first entity-framework-4.3
我有一个实体名册,有一系列球员.
public class Roster
{
public Roster()
{
Players = new List<Player>();
}
public int RosterId { get; set; }
[MaxLength(100)]
[Required]
public string RosterName { get; set; }
public ICollection<Player> Players { get; set; }
}
public class Player
{
public int PlayerId { get; set; }
[MaxLength(100)]
[Required]
public string PlayerName { get; set; }
public virtual ICollection<Roster> Rosters { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
我使用流畅的api定义了这种关系
// many to many Roster - Players
modelBuilder.Entity<Roster>()
.HasMany(t => t.Players)
.WithMany(t=>t.Rosters)
.Map(m =>
{
m.ToTable("RosterPlayers");
m.MapLeftKey("RosterId");
m.MapRightKey("PlayerId");
});
Run Code Online (Sandbox Code Playgroud)
我可以将球员保存到这样的名单中
var roster = rosterRepository.GetById(rosterId);
var player = playerRepository.GetById(playerId);
roster.Players.Add(player);
rosterRepository.Update(roster);
...
Run Code Online (Sandbox Code Playgroud)
但是,当我检索名单时,不会加载球员集合.我验证了数据是否存在所有正确的值,并且以下sql会提供数据.
SELECT * from Rosters r
INNER JOIN RosterPlayers rp on r.RosterId = rp.RosterId
INNER JOIN Players p ON p.PlayerId = rp.PlayerId
Run Code Online (Sandbox Code Playgroud)
我错过了什么?
Era*_*nga 12
将Players属性设置为虚拟,以便EF可以延迟加载集合.
public class Roster
{
//...........
public virtual ICollection<Player> Players { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
或者,您可以急切加载该Players集合.
var rosters = db.Rosters.Include(r => r.Players).ToList();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2027 次 |
| 最近记录: |