J'utilise Linq.Dynamic. J'ai déjà ajouté une autre extension SelectMany à tous pour créer un nouvel objet anonyme avec les données. Mais, j'ai rencontré un autre problème que je n'arrive pas à résoudre.
Je veux avoir le chaînage des méthodes d'extension comme suit, mais en utilisant les méthodes dynamiques:
var customerandorderflat = db.Customers
.SelectMany(c => c.Orders.SelectMany(o => o.Order_Details,
(ord, orddetail) => new
{
OrderID = ord.OrderID,
UnitPrice = orddetail.UnitPrice
}).DefaultIfEmpty(),
(cus, ord) => new
{
CustomerId = cus.CustomerID,
CompanyName = cus.CompanyName,
OrderId = ord.OrderID == null ? -1 : ord.OrderID,
UnitPrice = ord.UnitPrice
});
Idéalement, je voudrais enchaîner le SelectMany dynamique comme suit:
db.Customers.SelectMany(c => c.Orders.SelectMany("Order_Details", "new(outer.OrderID, inner.UnitPrice)"), "new(outer.CustomerID, inner.OrderID)");
Ou quelque chose à cet effet. Le problème est que je ne parviens pas à obtenir une signature correspondant.
J'ai essayé de nombreuses options différentes pour l'obtenir afin de permettre le chaînage. Mais cela ne fonctionne tout simplement pas. Je pense idéalement que cela ressemblerait à ceci:
public static IQueryable SelectMany(this IQueryable source, IQueryable innerExpression, string resultsSelector, params object[] values)
Mais, il ne reconnaît pas c => c.Orders comme IQueriable. J'ai également besoin de comprendre comment faire DefaultIfEmpty sur les résultats pour permettre les jointures à gauche.
Veuillez aider.
C'était une mauvaise définition. Erreur réelle lorsque la définition est correcte: impossible de convertir l'expression lambda en type 'System.Linq.IQueryable' car ce n'est pas un type délégué