Как мне выполнить внутреннее групповое присоединение в dotnet?C#

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

Сообщение Anonymous »

Я использую .NET 6 с Entity Framework. Это моя ситуация:
У меня есть BenefitEntity (со свойствами Name и Description и связью с BenefitCategory) и эта BenefitCategory, которая также имеет имя и описание.
В приложении , все имена и описания переведены, у нас есть таблица TranslationEntities, содержащая все переводы.
Вот три класса (я буду упрощать и помещать только те свойства, которые нам нужны). ):

Код: Выделить всё

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; }
}
Таблица TranslationEntities содержит все переводы для всех типов сущностей. Я хочу получить все BenefitEntity, используя GroupJoin для их имени/описания, и выполнить еще одно внутреннее соединение для его имени и описания BenefitCategory. Я могу сделать первое, но не могу сделать второе.
Вот что я сделал:

Код: Выделить всё

    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();
}
Начиная с этого момента, как я могу выполнить еще одно объединение для сущности категории, используя тот же запрос перевода, соединяя категориюEntity.Id с переводом.EntityId?

Подробнее здесь: https://stackoverflow.com/questions/784 ... -on-dotnet
Ответить

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

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

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

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

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