我试图用Linq制作我的模型(篮子)数组,在那个模型中我有另一个数组,所以当我用链接创建该模型时我得到了这个错误:
<Error>
<Message>An error has occurred.</Message>
<ExceptionMessage>
LINQ to Entities does not recognize the method 'HTTP.Webshop.API.WebAPI.Models.BasketLine[] ToArray[BasketLine](System.Collections.Generic.IEnumerable`1[HTTP.Webshop.API.WebAPI.Models.BasketLine])' method, and this method cannot be translated into a store expression.
</ExceptionMessage>
<ExceptionType>System.NotSupportedException</ExceptionType>
<StackTrace>
at System.Web.Http.ApiController.<InvokeActionWithExceptionFilters>d__1.MoveNext() --- End of stack trace from previous location where exception was thrown --- at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) at System.Web.Http.Dispatcher.HttpControllerDispatcher.<SendAsync>d__0.MoveNext()
</StackTrace>
</Error>
当我只返回一个Basket模型(只有BasketLines数组)时,我不会收到错误。
我的代码是:
return basketManager.GetList(context).Select(b => new Models.Basket
{
BasketId = b.BasketId,
CustomerId = b.CustomerId,
UserId = b.UserId,
ASPNETSessionId = b.ASPNETSessionId,
Created = b.Created,
CreatedOrder = b.CreatedOrder,
ShipmentMethodId = b.ShipmentMethodId,
ShipmentMethodName = (b.ShipmentMethod != null) ? b.ShipmentMethod.Description : null,
ShippingDocument = b.ShippingDocument,
VoucherCode = b.VoucherCode,
LockedSince = b.LockedSince,
PickupLocationId = b.PickupLocationId,
Reference = b.Reference,
Comments = b.Comments,
PurchaseNumber = b.PurchaseNumber,
DesiredDeliveryDate = b.DesiredDeliveryDate,
CompanyNameDelivery = b.CompanyNameDelivery,
NameDelivery = b.NameDelivery,
AddressDelivery = b.AddressDelivery,
Address2Delivery = b.Address2Delivery,
PostalCodeDeliver = b.PostalCodeDelivery,
CityDelivery = b.CityDelivery,
CountryISOCodeDelivery = b.CountryISOCodeDelivery,
InvoiceDiscount = b.InvoiceDiscount,
Modified = b.Modified,
BasketLines = b.BasketLines.Select(bl => new Models.BasketLine
{
BasketLineId = bl.BasketLineId,
BasketId = bl.BasketId,
ProductId = bl.ProductId,
ProductName = bl.Product.Name,
ProductVariantId = bl.ProductVariantId,
ProductVariantName = bl.ProductVariant.Name,
Quantity = bl.Quantity,
QuantityByPiece = bl.QuantityByPiece,
VATPercentage = bl.VATPercentage,
Amount = bl.Amount,
CalculatorAmount = bl.CalculatorAmount,
Discount = bl.Discount,
Reference = bl.Reference,
Comments = bl.Comments,
LockedSince = bl.LockedSince,
StockNr = bl.StockNr,
Created = bl.Created,
Modified = bl.Modified
}).ToArray()
}).ToArray();
答案 0 :(得分:3)
由于GetList
返回IQueryable
,因此在调用最后一个ToArray
之前不会执行实际的SQL查询。所以这里发生的是LINQ to SQL尝试将整个查询转换为SQL。当然,SQL中没有ToArray
类似物,翻译失败。
您可以做的是在开始投影到模型之前运行查询:
basketManager.GetList(context).ToList().Select(...