Как получить доступ к подтаблицам соединительной таблицы в EF Core?C#

Место общения программистов C#
Ответить
Anonymous
 Как получить доступ к подтаблицам соединительной таблицы в EF Core?

Сообщение Anonymous »

У меня есть этот метод, который извлекает все вознаграждения по UserId из таблицы UserReward:
public async Task GetAllRewardsByUserIdAsync(Guid userId)
{
var userRewards = await context.UserReward
.Include(d => d.User)
.Include(d => d.Reward)
.AsNoTracking()
.Where(d => d.ApplicationUserId == userId)
.ToListAsync();

IList rewards = new List();

foreach (Reward reward in userRewards)
{
rewards.Add(reward);
}

return rewards;
}

И, конечно, я получаю сообщение об ошибке «Невозможно преобразовать UserReward в вознаграждение». но как мне это сделать?
Вот таблица ApplicationUser, таблица Reward и таблица UserReward:
public class ApplicationUser : IdentityUser
{
public ApplicationUser()
{

}
public string FirstName { get; set; }
public string LastName { get; set; }
public Guid CategoryId { get; set; }
public Category Category { get; set; }
public IList Rewards { get; set; }
public DateTime CreatedDateTime { get; set; }
}

public class Reward
{
public Guid RewardId { get; set; }
public string Name { get; set; }
public bool HasBeenUsed { get; set; }
public IList Users { get; set; }
public DateTime ExpiresOn { get; set; }
}

public class UserReward
{
public Guid ApplicationUserId { get; set; }
public ApplicationUser User { get; set; }

public Guid RewardId { get; set; }
public Reward Reward { get; set; }
}


Подробнее здесь: https://stackoverflow.com/questions/791 ... in-ef-core
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»