У меня есть преимущество (с именем и свойствами описания и отношения с BenefitCategory), и эта выгода, которая также имеет имя и описание. нуждается): < /p>
Код: Выделить всё
public class BenefitEntity
{
public Guid Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public Guid BenefitCategoryId { get; set; }
public virtual BenefitCategoryEntity CategoryEntity { get; set; }
}
public class BenefitCategoryEntity
{
public Guid Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
}
public class TranslationEntity
{
public Guid EntityId { get; set; }
public string Language { get; set; }
public string Property { get; set; }
public string Value { get; set; }
}
< /code>
Таблица TranslageEnties содержит все переводы для всех типов объектов. Я хочу получить все выгоды, используя GroupJoin для их имени/описания и сделать еще одно внутреннее соединение для его имени и описания. Я могу сделать первый, но не могу сделать второй. < /P>
Вот что я сделал: < /p>
public async Task GetAllBenefitEntitiesAsync()
{
var benefitsQuery = Entities
.Include(a => a.CategoryEntity);
var translationsQuery = DbContext.TranslationsEntities!
.AsNoTracking()
.Where(e => e.Language.Equals(LANGUAGE));
var benefits = await benefitsQuery.ToListAsync();
var result = benefits
.GroupJoin(
translationsQuery,
benefit => benefit.Id,
translation => translation.EntityId,
(benefit, translation) => new { Benefit = benefit, Translation = translation })
.Select(result => new BenefitEntity
{
// Benefit Name and Description from joined translations
Name = result.Translation.FirstOrDefault(e => e.Property.Equals(nameof(BenefitEntity.Name)))?.Value ?? result.Benefit.Name,
Description = result.Translation.FirstOrDefault(e => e.Property.Equals(nameof(BenefitEntity.Description)))?.Value ?? result.Benefit.Description,
Id = result.Benefit.Id,
CategoryEntity = result.Benefit.CategoryEntity,
BenefitCategoryId = result.Benefit.BenefitCategoryId,
})
.AsQueryable();
return result.ToList();
}
Подробнее здесь: https://stackoverflow.com/questions/784 ... -on-dotnet
Мобильная версия