jan*_*naj 1 c# sql entity-framework
我的模特看起来像:
public class ReturnItem
{
public int returnItemId { get ; set; }
public int returnRequestId { get; set; }
public int quantity { get; set; }
public string item { get; set; }
}
public class ReturnRequest
{
public int returnRequestId { get; set; }
public string orderNumber { get; set; }
public IEnumerable<ReturnItem> returnItems { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
我有以下查询:
SELECT item, sum(quantity)
FROM ReturnItem
JOIN ReturnRequest
ON ReturnRequest.returnRequestId = ReturnItem.returnRequestId
WHERE ReturnRequest.orderNumber = '1XX'
GROUP BY item
Run Code Online (Sandbox Code Playgroud)
如何将查询转换为Entity Framework并返回List<ReturnItem>?我可以用.Include而不是.Join吗?
from ri in db.ReturnItems
join rr in db.ReturnRequests
on ri.returnRequestId equals rr.returnRequestId
where rr.orderNumber == "1XX"
group ri by ri.item into g
select new {
Item = g.Key,
Quantity = g.Sum(i => i.quantity)
}
Run Code Online (Sandbox Code Playgroud)
你不能使用Include而不是Join因为Include翻译成左外连接但你需要内部加入.
但您可以使用navigation属性隐式执行连接:
db.ReturnRequests
.Where(rr => rr.orderNumber == "1XX")
.SelectMany(rr => rr.returnItems)
.GroupBy(ri => ri.item)
.Select(g => new {
Item = g.Key,
Quantity = g.Sum(ri => ri.quantity)
});
Run Code Online (Sandbox Code Playgroud)