left join 一个子查询,这种sql 怎么用linq实现

antony1029 2016-03-31 02:26:36
select *  
FROM Customer c
left join(
Select o.CustomerId ,sum(o.OrderTotalAmount) as OrderTotalAmount from [order] o
group by o.CustomerId
)ot
on c.id=ot.CustomerId

这种sql 用linq怎么实现
...全文
427 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
antony1029 2016-04-01
  • 打赏
  • 举报
回复
引用 3 楼 q107770540 的回复:
var query = from c in db.Customer
            join ot in db.order.GroupBy(o=>o.CustomerId).Select(o=>new{CustomerId=o.Key,OrderTotalAmount=o.Sum(x=>x.OrderTotalAmount) })
			on c.id equals ot.CustomerId into lg
			from c in lg.DefaultIfEmpty()
			select c;
感谢,非常正确。比我的执行效率要高。
q107770540 2016-03-31
  • 打赏
  • 举报
回复
var query = from c in db.Customer
            join ot in db.order.GroupBy(o=>o.CustomerId).Select(o=>new{CustomerId=o.Key,OrderTotalAmount=o.Sum(x=>x.OrderTotalAmount) })
			on c.id equals ot.CustomerId into lg
			from c in lg.DefaultIfEmpty()
			select c;
antony1029 2016-03-31
  • 打赏
  • 举报
回复
还有其他的写法吗??
antony1029 2016-03-31
  • 打赏
  • 举报
回复
            var q =
from c in customer
join o in _orde on c.Id
equals o.CustomerId into orders
select new
{
c.Username,
OrderTotal = orders.Sum(i=>i.OrderTotal)

};
Join操作 适用场景:在我们表关系中有一对一关系,一对多关系,多对多关系等。对各个表之间的关系,就用这些实现对多个表的操作。 说明:在Join操作中,分别为Join(Join查询), SelectMany(Select一对多选择)和GroupJoin(分组Join查询)。 该扩展方法对两个序列中键匹配的元素进行inner join操作 SelectMany 说明:我们在写查询语句时,如果被翻译成SelectMany需要满足2个条件。1:查询语句中没有join和into,2:必须出现EntitySet。在我们表关系中有一对一关系,一对多关系,多对多关系等,下面分别介绍一下。 1.一对多关系(1 to Many): var q = from c in db.Customers from o in c.Orders where c.City == "London" select o; 语句描述:Customers与Orders是一对多关系。即Orders在Customers类中以EntitySet形式出现。所以第二个 from是从c.Orders而不是db.Orders里进行筛选。这个例子在From子句中使用外键导航选择伦敦客户的所有订单。 var q = from p in db.Products where p.Supplier.Country == "USA" && p.UnitsInStock == 0 select p; 语句描述:这一句使用了p.Supplier.Country条件,间接关联了Supplier表。这个例子在Where子句中使用外键导航筛选其供应商在美国且缺货的产品。生成SQL语句为: SELECT [t0].[ProductID], [t0].[ProductName], [t0].[SupplierID], [t0].[CategoryID],[t0].[QuantityPerUnit],[t0].[UnitPrice], [t0].[UnitsInStock], [t0].[UnitsOnOrder],[t0].[ReorderLevel], [t0].[Discontinued] FROM [dbo].[Products] AS [t0] LEFT OUTER JOIN [dbo].[Suppliers] AS [t1] ON [t1].[SupplierID] = [t0].[SupplierID] WHERE ([t1].[Country] = @p0) AND ([t0].[UnitsInStock] = @p1) -- @p0: Input NVarChar (Size = 3; Prec = 0; Scale = 0) [USA] -- @p1: Input Int (Size = 0; Prec = 0; Scale = 0) [0] 2.多对多关系(Many to Many): var q = from e in db.Employees from et in e.EmployeeTerritories where e.City == "Seattle" select new { e.FirstName, e.LastName, et.Territory.TerritoryDescription }; 说明:多对多关系一般会涉及三个表(如果有一个表是自关联的,那有可能只有2个表)。这一句语句涉及Employees, EmployeeTerritories, Territories三个表。它们的关系是1:M:1。Employees和Territories没有很明确的关系。 LINQ to SQL语句之Join和Order By部分代码 语句描述:这个例子在From子句中使用外键导航筛选在西雅图的雇员,同时列出其所在地区。这条生成SQL语句为: SELECT [t0].[FirstName], [t0].[LastName], [t2].[TerritoryDescription] FROM [dbo].[Employees] AS [t0] CROSS JOIN [dbo].[EmployeeTerritories] AS [t1] INNER JOIN [dbo].[Territories] AS [t2] ON [t2].[TerritoryID] = [t1].[TerritoryID] WHERE ([t0].[City] = @p0) AND ([t1].[EmployeeID] = [t0].[EmployeeID]) -- @p0: Input NVarChar (Size = 7; Prec = 0; Scale = 0) [Seattle] 。。。。。。。。。。。。。。。。。。。。。。。。。。。

8,493

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 LINQ
社区管理员
  • LINQ
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧