LinqToSql生成的sql语句自动添加了orderby还缺了个左链接

romanchaos 2014-06-03 05:54:10

var query = from p in db.TheOrder_merge
join g in db.TheOrder on p.Id equals g.Pid into lstOrder
join s in db.The_Order_ShippingFee on p.Id equals s.Orderid into lstShipFee
where lstOrder.All(q => q.Solddate < DateTime.Now.AddMonths(-3) && (q.Resend == 2 || q.deleteid == 2))
select new { Merge = p, LstOrder = lstOrder, LstShipFee = lstShipFee };


SELECT [t0].[Id], [t0].[WareHouseId], [t0].[CustomerId], [t0].[CustomerName], [t0].[CountryName], [t0].[CountryCode], [t0].[Address1], [t0].[Address2], [t0].[Province], [t0].[City], [t0].[ZipCode], [t0].[Email], [t0].[MobilePhoneNo], [t0].[ShippedOnDate], [t0].[ShippingServiceId], [t0].[IsComplete], [t0].[TrackingNo], [t0].[Remarks], [t0].[AuditId], [t0].[Isrepeat], [t0].[Isstamp], [t0].[SenderId], [t0].[Freight], [t0].[Cid], [t0].[Oid], [t0].[Modidate], [t0].[Delflag], [t0].[goodprofit], [t0].[Parcelweight], [t0].[SendDate], [t0].[PackageNo], [t1].[Id] AS [Id2], [t1].[IsThird], [t1].[SKUId], [t1].[CustomerId] AS [CustomerId2], [t1].[CustomerName] AS [CustomerName2], [t1].[CountryName] AS [CountryName2], [t1].[CountryCode] AS [CountryCode2], [t1].[Address1] AS [Address12], [t1].[Address2] AS [Address22], [t1].[Province] AS [Province2], [t1].[City] AS [City2], [t1].[ZipCode] AS [ZipCode2], [t1].[Email] AS [Email2], [t1].[MobilePhoneNo] AS [MobilePhoneNo2], [t1].[SalesRecordNumber], [t1].[trackingNo] AS [trackingNo2], [t1].[WareHouseId] AS [WareHouseId2], [t1].[SiteId], [t1].[AccountId], [t1].[TransactionID], [t1].[PayPalTransactionID], [t1].[ShippedOnDate] AS [ShippedOnDate2], [t1].[PaidOnDate], [t1].[SalePrice], [t1].[TotalPrice], [t1].[PaymentMethod], [t1].[ShippingandHandling], [t1].[Quantity], [t1].[ItemTitle], [t1].[ItemNumber], [t1].[Remarks] AS [Remarks2], [t1].[Currid], [t1].[ShippingService], [t1].[Shipfee], [t1].[Resend], [t1].[Returned], [t1].[Refundid], [t1].[IsRefunder], [t1].[Refunder], [t1].[RefundChecker], [t1].[SaleManID], [t1].[CSSId], [t1].[SenderId] AS [SenderId2], [t1].[platformId], [t1].[AuditId] AS [AuditId2], [t1].[isrepeat] AS [isrepeat2], [t1].[isstamp] AS [isstamp2], [t1].[isPicking], [t1].[freight] AS [freight2], [t1].[deleteid], [t1].[reissuing], [t1].[Refunds], [t1].[RefundsDate], [t1].[orderid], [t1].[CustomLabel], [t1].[eBayfees], [t1].[ppfees], [t1].[adid], [t1].[ShippingServiceId] AS [ShippingServiceId2], [t1].[Pickingid], [t1].[egroup], [t1].[goodprofit] AS [goodprofit2], [t1].[msnon], [t1].[caseon], [t1].[eFeedback], [t1].[feedbacktitle], [t1].[StayAssess], [t1].[StayAssessStatus], [t1].[eubon], [t1].[erraddress], [t1].[ebayshiped], [t1].[Pid], [t1].[Cid] AS [Cid2], [t1].[IsSplit], [t1].[goodprice], [t1].[Oname], [t1].[Oid] AS [Oid2], [t1].[Modidate] AS [Modidate2], [t1].[Pickingstatus], [t1].[Linestatus], [t1].[Solddate], [t1].[Packfees], [t1].[PayPalId], [t1].[ResendFatherID], [t1].[exportstatus], [t1].[oldid], [t1].[ReasonResend], [t1].[ReasonRefund], [t1].[ebayshippdate], [t1].[CustomerNote], [t1].[rebefgoodprofit], [t1].[Addtype], [t1].[BbeId], [t1].[RefundType], [t1].[SaleGoodProfit], [t1].[ReBefSaleGoodProfit], [t1].[IsSynTran], [t1].[HasAutoForbi], (
SELECT COUNT(*)
FROM [dbo].[TheOrder] AS [t3]
WHERE ([t0].[Id]) = [t3].[Pid]
) AS [value]
FROM [dbo].[TheOrder_merge] AS [t0]
LEFT OUTER JOIN [dbo].[TheOrder] AS [t1] ON ([t0].[Id]) = [t1].[Pid]
WHERE NOT (EXISTS(
SELECT NULL AS [EMPTY]
FROM [dbo].[TheOrder] AS [t2]
WHERE ((
(CASE
WHEN ([t2].[Solddate] < '2014/3/3 17:04:21') AND (([t2].[Resend] = 2) OR ([t2].[deleteid] = 2)) THEN 1
ELSE 0
END)) = 0) AND (([t0].[Id]) = [t2].[Pid])
))
ORDER BY [t0].[Id], [t1].[Id]

第一个是linq,第二个是生成的sql语句,现在有两个问题:1、sql语句中缺少对he_Order_ShippingFee的左链接:2、生成的sql语句多了ORDER BY [t0].[Id], [t1].[Id],请问原因是什么呢?
...全文
1145 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
romanchaos 2014-06-06
  • 打赏
  • 举报
回复
引用 6 楼 caozhy 的回复:
sql没有对应group join的语法。 group join需要orderby,然后再分出组来
请问缺了的The_Order_ShippingFee是否会以第二句sql来执行获取数据呢?因为在vs和linqpad我都只能找到上面那句sql
threenewbee 2014-06-05
  • 打赏
  • 举报
回复
sql没有对应group join的语法。 group join需要orderby,然后再分出组来
romanchaos 2014-06-05
  • 打赏
  • 举报
回复
引用 4 楼 q107770540 的回复:
join g in db.TheOrder on p.Id equals g.Pid into lstOrder 这是GROUP JOIN,不是LEFT JOIN
谢谢,那么为何The_Order_ShippingFee在sql中体现不出group join出来呢?其实最重要的还是最后那个ORDER BY [t0].[Id], [t1].[Id],排这个序对分页的效率有影响。
q107770540 2014-06-05
  • 打赏
  • 举报
回复
join g in db.TheOrder on p.Id equals g.Pid into lstOrder 这是GROUP JOIN,不是LEFT JOIN
romanchaos 2014-06-04
  • 打赏
  • 举报
回复
引用 2 楼 q107770540 的回复:
var query = from p in db.TheOrder_merge              join g in db.TheOrder on p.Id equals g.Pid into lstOrder from g in lstOrder.DefaultIfEmpty()              join s in db.The_Order_ShippingFee on p.Id equals s.Orderid into lstShipFee from s in lstShipFee.DefaultIfEmpty()            .... 这才是左连接
单独使用
join g in db.TheOrder on p.Id equals g.Pid into lstOrder
也是会生成left join的,如theOrder表就是左链了;问题是同样的写法The_Order_ShippingFee表就走不通,而且整句sql后还添加了ORDER BY [t0].[Id], [t1].[Id]这让我十分疑惑。
q107770540 2014-06-04
  • 打赏
  • 举报
回复
var query = from p in db.TheOrder_merge              join g in db.TheOrder on p.Id equals g.Pid into lstOrder from g in lstOrder.DefaultIfEmpty()              join s in db.The_Order_ShippingFee on p.Id equals s.Orderid into lstShipFee from s in lstShipFee.DefaultIfEmpty()            .... 这才是左连接
q107770540 2014-06-04
  • 打赏
  • 举报
回复
你写的LINQ语句里又没有用LEFT JOIN,那它生成的SQL语句中怎么会有呢?
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,492

社区成员

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

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