Код: Выделить всё
SELECT * FROM Authors A
LEFT JOIN Books B ON B.AuthorId = A.Id
LEFT JOIN BookReviews R ON R.BookId=B.Id AND R.Edition=B.Edition
WHERE A.Id = @AuthorId AND R.Approved='Y'
Код: Выделить всё
var results = await context.Authors
.Include(i => i.Books)
.ThenInclude(i => i.BookReviews)
.FirstOrDefaultAsync(x => x.Id == author && x.Books.....
Свойство навигации для этих двух таблиц создается в сущности Books. (Не спрашивайте меня)
Код: Выделить всё
builder.HasOne(s => s.BookReview)
.WithOne(d => d.Book)
.HasForeignKey(d => new { d.BookId, d.Edition })
.HasPrincipalKey(s => new { s.Id, s.Edition })
.IsRequired(false);
Подробнее здесь: https://stackoverflow.com/questions/797 ... sults-on-e
Мобильная версия