【问题标题】:SQL Server 2005: what LINQ generated query is better - with "Where()" or "Any()"?SQL Server 2005:使用“Where()”还是“Any()”,哪种 LINQ 生成的查询更好?
【发布时间】:2010-08-31 10:13:00
【问题描述】:
var query = from c in db.Customers select c;
query = query.Where(c => c.Orders.Where(o => o.OrderItems.Where(oi => oi.SellerID == sellerID).Count() > 0).Count() > 0);

生成 SQL:

SELECT [t0].[CustomerID], [t0].[FirstName], [t0].[LastName], [t0].[Email], [t0].[Company], [t0].[BillingAddress1], [t0].[BillingAddress2], [t0].[ShippingAddress1], [t0].[ShippingAddress2], [t0].[Phone], [t0].[Mobile], [t0].[Fax], [t0].[CreateDT], [t0].[UpdateDT], [t0].[DefaultLanguage], [t0].[DefaultPaymentInfo], [t0].[Active], [t0].[Title], [t0].[LoginID], [t0].[ReferringLink], [t0].[CustomerIP], [t0].[CustomerCountryByIP], [t0].[VatID]
FROM [dbo].[Customers] AS [t0]
WHERE ((
    SELECT COUNT(*)
    FROM [dbo].[Orders] AS [t1]
    WHERE (((
        SELECT COUNT(*)
        FROM [dbo].[OrderItems] AS [t2]
        WHERE ([t2].[SellerID] = 2428) AND ([t2].[OrderID] = [t1].[OrderID])
        )) > 0) AND ([t1].[CustomerID] = [t0].[CustomerID])
    )) > 0

var query = from c in db.Customers select c;
query = query.Where(c => c.Orders.Any(o => o.OrderItems.Any(oi => oi.SellerID == sellerID)));

生成 SQL:

SELECT [t0].[CustomerID], [t0].[FirstName], [t0].[LastName], [t0].[Email], [t0].[Company], [t0].[BillingAddress1], [t0].[BillingAddress2], [t0].[ShippingAddress1], [t0].[ShippingAddress2], [t0].[Phone], [t0].[Mobile], [t0].[Fax], [t0].[CreateDT], [t0].[UpdateDT], [t0].[DefaultLanguage], [t0].[DefaultPaymentInfo], [t0].[Active], [t0].[Title], [t0].[LoginID], [t0].[ReferringLink], [t0].[CustomerIP], [t0].[CustomerCountryByIP], [t0].[VatID]
FROM [dbo].[Customers] AS [t0]
WHERE EXISTS(
    SELECT NULL AS [EMPTY]
    FROM [dbo].[Orders] AS [t1]
    WHERE (EXISTS(
        SELECT NULL AS [EMPTY]
        FROM [dbo].[OrderItems] AS [t2]
        WHERE ([t2].[SellerID] = 2428) AND ([t2].[OrderID] = [t1].[OrderID])
        )) AND ([t1].[CustomerID] = [t0].[CustomerID])
    )

实际的执行计划看起来是一样的,但是不管怎样,用什么更好呢?谢谢。

【问题讨论】:

    标签: sql-server sql-server-2005 ssms sql-server-2008-express


    【解决方案1】:

    使用EXISTS,数据库可以立即清楚地知道 1 条匹配记录就足够了。因此,一旦它找到任何东西,它就可以返回。有一个计数......可能不会使用优化。但是既然你说执行计划是一样的,那我猜MS SQL明白它是如何优化查询的。

    我个人会选择存在,因为它准确地描述了您的需求。具有非零计数不太清楚恕我直言。

    【讨论】:

      猜你喜欢
      • 2012-06-15
      • 2010-10-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-10-24
      相关资源
      最近更新 更多