繁体   English   中英

EF Core 包括查询

[英]EF Core Includes query

我正在尝试使用 SQLite 将用户实体保存到 EFCore 中的 Room 实体。 保存更改后,我再次查询数据库以获取房间实体中更新的用户列表。 目前,它返回 0 个用户,如果我在运行此查询后用断点停止代码并查看数据库表,我可以看到用户与正确的房间相关联,但我仍然有 0 个结果。 我很好奇我的设计是否有问题? 我需要将用户链接回房间的东西吗?

返回 0 个用户的代码 -

public async Task<ServiceResponse<MatchRoom>> RegisterUser(AppState state)
{
    //Update the db with connection ID incase we need it later
    var update = _context.Update(state.user);
    if (update != null)
    {
        //The user object is saved here
        await _context.SaveChangesAsync();
        //Here I query a room, that the user is assigned to, but get nothing.
        var room = _context.MatchRooms.Include("Users");
}

我有以下 dbcontext

public class DataContext : DbContext
{
    public DataContext(DbContextOptions<DataContext> options) : base(options)
    {
        //
    }
    
    public DbSet<User> Users { get; set; }
    public DbSet<MatchRoom> MatchRooms { get; set; }
    public DbSet<Message> Messages { get; set; }
    
    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<MatchRoom>()
            .HasMany<User>(u => u.Users);
            
        modelBuilder.Entity<MatchRoom>()
            .HasMany<Message>(m => m.Messages);
            
        modelBuilder.Entity<Message>()
            .HasOne<User>(r => r.SentBy);
    }    
}

public class MatchRoom
{
    public int MatchRoomId { get; set; }
    public string MatchRoomCode { get; set; }
    [ValidateComplexType]
    public List<User> Users { get; set; } = new List<User>();
    public User CreatedBy { get; set; }
    public List<Message> Messages { get; set; }
}

public class User
{
    public int UserId { get; set; }
    public string UserCode { get; set; }
    [Required(ErrorMessage ="You must specify a username")]
    [StringLength(20,MinimumLength=1,ErrorMessage="Please enter a username no longer than 20 characters")]
    public string Username { get; set; }
    public string ConnectionId { get; set; }
}

public class Message
{
    public int MessageId { get; set; }
    public string Text { get; set; }
    public User SentBy { get; set; }
}

代码 D b

您只是声明查询,而不是执行它。

更改以下行 -

var room = _context.MatchRooms.Include("Users");

至 -

var room = await _context.MatchRooms.Include(p=> p.Users).ToListAsync();

这将为您提供所有MatchRoom及其相关User列表的列表。

不确定如何查询已保存用户分配到的房间,因为我在User MatchRoomId中看不到任何外键属性,例如可用于过滤查询的 MatchRoomId。 我猜现在它们正在由 EF 生成的影子键处理。

User class 中声明外键属性 -

public int MatchRoomId { get; set; }

然后你可以查询一个房间,保存的用户被分配到喜欢 -

var room = await _context.MatchRooms.Include(p=> p.Users).FirstOrDefaultAsync(p=> p.MatchRoomId == state.user.MatchRoomId)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM