Я читал разные решения и пробовал разные реализации без каких-либо результатов. При использовании другой реализации ошибка всегда одна и та же: «System.InvalidOperationException: перечислитель не смог выполнить MoveNextAsync».
Здесь генерируется исключение.
var portfolioTrades = await _context
.Portfolios
.Include(PortfolioEntityTypeConfiguration.TradesList)
.SingleOrDefaultAsync(x => x.id == id);
Включение обрабатывается способом
builder.OwnsMany<Trade>(TradesList, x =>
{
x.WithOwner().HasForeignKey("portfolio_id");
x.ToTable("product_trade", SchemaNames.Public);
x.Property<TradeID>("id");
x.Property<DateTimeOffset>("_date").HasColumnName("date");
x.Property("_details").HasColumnName("details");
x.Property<Guid>("_schemaId").HasColumnName("schema_id");
x.HasKey(x => x.id);
});
EF выполнит этот запрос и вернет 1 запись
SELECT t.id, t.description, t.end_client_name, t.name, t0.id, t0.details, t0.portfolio_id
FROM (
SELECT p.id, p.description, p.end_client_name, p.name
FROM account.portfolio AS p
WHERE p.id = '3adcaff1-de64-4ae3-b8b7-c390d76aa0bd'
LIMIT 2
) AS t
LEFT JOIN product_trade AS t0 ON t.id = t0.portfolio_id
ORDER BY t.id, t0.id
Здесь ниже Сущности
public class Trade : Entity
{
public TradeID id { get; private set; }
private DateTimeOffset _date { get; set; }
public JObject _details { get; set; }
private Guid _schemaId { get; set; }
private Trade()
{
id = new TradeID(Guid.NewGuid());
}
private Trade( DateTimeOffset date, string details, Guid schema_id)
{
id = new TradeID(Guid.NewGuid());
_date = date;
_schemaId = schema_id;
_details = JsonConvert.DeserializeObject<JObject>(details);
}
internal static Trade Create(DateTimeOffset date, string details, Guid schema_id)
{
return new Trade(date, details, schema_id);
}
}
}
public class Portfolio : Entity, IAggregateRoot
{
public PortfolioID id { get; private set; }
private string _name { get; set; }
private string _end_client_name { get; set; }
private string _description { get; set; }
private readonly List<Trade> _trades;
private Portfolio()
{
_trades = new List<Trade>();
}
}
// ошибка
System.InvalidOperationException: Enumerator failed to MoveNextAsync.
at Microsoft.EntityFrameworkCore.Query.ShapedQueryCompilingExpressionVisitor.SingleOrDefaultAsync[TSource](IAsyncEnumerable`1 asyncEnumerable, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.Query.ShapedQueryCompilingExpressionVisitor.SingleOrDefaultAsync[TSource](IAsyncEnumerable`1 asyncEnumerable, CancellationToken cancellationToken)
at Rx.Products.Infrastructure.Domain.Portfolios.PortfolioRepository.GetByPortfolioIdAsync(PortfolioID id) in ....\PortfolioRepository.cs:line 37
at Rx.Products.Application.Portfolios.CreateTrade.CreateTradeCommandHandler.Handle(CreateTradeCommand request, CancellationToken cancellationToken) in ...\CreateTradeCommandHandler.cs:line 19
at MediatR.Pipeline.RequestPreProcessorBehavior`2.Handle(TRequest request, CancellationToken cancellationToken, RequestHandlerDelegate`1 next)
at MediatR.Pipeline.RequestPostProcessorBehavior`2.Handle(TRequest request, CancellationToken cancellationToken, RequestHandlerDelegate`1 next)
at Rx.Products.API.TradesController.RegisterCustomer(CreateTradeRequest new_trade) in ....\TradesController.cs:line 65
at Microsoft.AspNetCore.Mvc.Infrastructure.ActionMethodExecutor.TaskOfIActionResultExecutor.Execute(IActionResultTypeMapper mapper, ObjectMethodExecutor executor, Object controller, Object[] arguments)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.<InvokeActionMethodAsync>g__Awaited|12_0(ControllerActionInvoker invoker, ValueTask`1 actionResultValueTask)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.<InvokeNextActionFilterAsync>g__Awaited|10_0(ControllerActionInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Rethrow(ActionExecutedContextSealed context)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.<InvokeInnerFilterAsync>g__Awaited|13_0(ControllerActionInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeFilterPipelineAsync>g__Awaited|19_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeAsync>g__Awaited|17_0(ResourceInvoker invoker, Task task, IDisposable scope)
at Microsoft.AspNetCore.Routing.EndpointMiddleware.<Invoke>g__AwaitRequestTask|6_0(Endpoint endpoint, Task requestTask, ILogger logger)
at Microsoft.AspNetCore.Authorization.AuthorizationMiddleware.Invoke(HttpContext context)
at Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)
HEADERS
=======
Accept: */*
Accept-Encoding: gzip, deflate, br
Connection: keep-alive
Content-Length: 726
Content-Type: application/json
Host: localhost:54315
User-Agent: PostmanRuntime/7.24.1
Postman-Token: 2aabfa69-9d5c-4637-9d48-02a713077235
справочник ms об отношении генерируют ту же ошибку. Спасибо за ваше время.
FirstOrDefaultAsync
иSingleOrDefault
. См. this и это проблемы. - person Guru Stron   schedule 14.05.2020