[英]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; }
}
您只是声明查询,而不是执行它。
更改以下行 -
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.